summaryrefslogtreecommitdiff
path: root/2024/16/python/main.py
diff options
context:
space:
mode:
authormhsn <mail@mhsn.net>2024-12-31 11:32:17 +0000
committermhsn <mail@mhsn.net>2024-12-31 11:32:17 +0000
commitd5c63db4a6fc07f8282cf89b743fdc65e9efba53 (patch)
tree8fb85703af66a226f4189f61c29d640119ed4544 /2024/16/python/main.py
parent669fe7076e605da673de92aa7a3d75468586feca (diff)
downloadaoc-d5c63db4a6fc07f8282cf89b743fdc65e9efba53.tar.gz
aoc-d5c63db4a6fc07f8282cf89b743fdc65e9efba53.zip
2024-16 python p1
Diffstat (limited to '2024/16/python/main.py')
-rw-r--r--2024/16/python/main.py29
1 files changed, 29 insertions, 0 deletions
diff --git a/2024/16/python/main.py b/2024/16/python/main.py
new file mode 100644
index 0000000..f66fe94
--- /dev/null
+++ b/2024/16/python/main.py
@@ -0,0 +1,29 @@
+from fileinput import input
+
+grid = {
+ complex(idx, idy): c
+ for idy, line in enumerate(input())
+ for idx, c in enumerate(line.strip())
+}
+start = next(p for p, c in grid.items() if c == "S")
+end = next(p for p, c in grid.items() if c == "E")
+
+q = [(0, (start, 1))]
+seen = set()
+while q:
+ curr = min(q, key=lambda x: x[0])
+ d, (pos, vel) = curr
+ q.remove(curr)
+ if (pos, vel) in seen:
+ continue
+ if pos == end:
+ silver = d
+ break
+ seen.add((pos, vel))
+
+ if grid[pos + vel] != "#":
+ q.append((d + 1, (pos + vel, vel)))
+ q.append((d + 1000, (pos, vel * 1j)))
+ q.append((d + 1000, (pos, vel * -1j)))
+
+print("silver:", silver)