summaryrefslogtreecommitdiff
path: root/2024/15/python/main.py
blob: 9ea386a5d867604da11496437b7ae099c53e6590 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
from fileinput import input
from itertools import takewhile

inp = map(str.strip, input())

grid = {
    complex(x, y): c
    for y, line in enumerate(takewhile(bool, inp))
    for x, c in enumerate(line)
}
moves = "".join(inp)

bot = next(p for p, c in grid.items() if c == "@")


def push(x, v):
    match grid[x]:
        case ".":
            return True
        case "#":
            return False
        case _ if push(x + v, v):
            grid[x + v] = grid[x]
            return True


dirs = {">": 1, "v": 1j, "<": -1, "^": -1j}
for m in map(dirs.get, moves):
    if push(bot, m):
        grid[bot] = "."
        bot += m


silver = int(sum(p.real + 100 * p.imag for p, c in grid.items() if c == "O"))
gold = 0

print("silver:", silver)
print("gold:", gold)