-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathday06.py
executable file
·82 lines (58 loc) · 1.19 KB
/
day06.py
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#!/usr/bin/env python3
from utils.all import *
advent.setup(2024, 6)
fin = advent.get_input()
grid = read_char_matrix(fin)
ans1 = ans2 = 0
for r, row in enumerate(grid):
for c, char in enumerate(row):
if char == '^':
startpos = r, c
def calc(grid, startpos):
r, c = startpos
dr, dc = -1, 0
seen = set()
while 1:
# oob?
if not (0 <= r < len(grid) and 0 <= c < len(grid[0])):
break
# hit a wall?
if grid[r][c] == '#':
r -= dr
c -= dc
dr, dc = dc, -dr
continue
k = (r, c, dr, dc)
if k in seen:
return True
seen.add(k)
r += dr
c += dc
return False
r, c = startpos
dr, dc = -1, 0
seen = set()
history = []
while 1:
seen.add((r, c))
history.append((r, c, dr, dc))
if not (0 <= r + dr < len(grid) and 0 <= c + dc < len(grid[0])):
break
if grid[r + dr][c + dc] == '#':
dr, dc = dc, -dr
r += dr
c += dc
ans1 = len(seen)
advent.print_answer(1, ans1)
prev = None
for r, row in enumerate(grid):
for c, char in enumerate(row):
if (r, c) not in seen or (r, c) == startpos:
continue
if prev is not None:
grid[prev[0]][prev[1]] = '.'
grid[r][c] = '#'
prev = r, c
ans2 += calc(grid, startpos)
# 1995 wrong
advent.print_answer(2, ans2)