summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormhsn <mail@mhsn.net>2024-12-20 10:08:32 +0000
committermhsn <mail@mhsn.net>2024-12-20 10:08:32 +0000
commitb21aae680d29698242e08991d90171f1fc2aeeaf (patch)
treee4865689f4c484e05d9720bc6bc93c5b7c748d0a
parent7013617101edf1eb4d974c4a5abec15d3f63a29d (diff)
downloadaoc-b21aae680d29698242e08991d90171f1fc2aeeaf.tar.gz
aoc-b21aae680d29698242e08991d90171f1fc2aeeaf.zip
2024-20 python p2
-rw-r--r--2024/20/python/main.py23
1 files changed, 11 insertions, 12 deletions
diff --git a/2024/20/python/main.py b/2024/20/python/main.py
index c2f3f73..bec6ebf 100644
--- a/2024/20/python/main.py
+++ b/2024/20/python/main.py
@@ -21,19 +21,18 @@ while q:
continue
q.append((x, t + 1))
-cheats = []
-for wall in (p for p, c in grid.items() if c == "#"):
- for d in [1, -1, 1j, -1j]:
- if (x := wall - d) not in grid or grid[x] == "#":
- continue
- if (y := wall + d) not in grid or grid[y] == "#":
- continue
- if (saved := times[y] - times[x] - 2) <= 0:
- continue
- cheats.append(saved)
-silver = sum(1 for c in cheats if c >= 100)
-gold = 0
+def cheat(x, y, d):
+ dist = int(abs(x.real - y.real) + abs(x.imag - y.imag))
+ if dist > d:
+ return False
+ saved = times[y] - times[x] - dist
+ return saved >= 100
+
+
+silver = sum(cheat(x, y, 2) for x in times.keys() for y in times.keys())
+gold = sum(cheat(x, y, 20) for x in times.keys() for y in times.keys())
+
print("silver:", silver)
print("gold:", gold)