diff options
author | mhsn <mail@mhsn.net> | 2024-12-20 10:08:32 +0000 |
---|---|---|
committer | mhsn <mail@mhsn.net> | 2024-12-20 10:08:32 +0000 |
commit | b21aae680d29698242e08991d90171f1fc2aeeaf (patch) | |
tree | e4865689f4c484e05d9720bc6bc93c5b7c748d0a | |
parent | 7013617101edf1eb4d974c4a5abec15d3f63a29d (diff) | |
download | aoc-b21aae680d29698242e08991d90171f1fc2aeeaf.tar.gz aoc-b21aae680d29698242e08991d90171f1fc2aeeaf.zip |
2024-20 python p2
-rw-r--r-- | 2024/20/python/main.py | 23 |
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) |