-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathday11.py
111 lines (85 loc) · 2.41 KB
/
day11.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
from __future__ import annotations
from typing import List
from pprint import pprint
Grid = List[List[str]]
adjacent = [(-1, -1), (-1, 0), (-1, 1), (0, -1), (0, 1), (1, -1), (1, 0), (1, 1)]
def evolve(grid: Grid, i: int, j: int) -> str:
rows = len(grid)
cols = len(grid[0])
neighbors = {"#": 0, "L": 0, ".": 0}
for adj_i, adj_j in adjacent:
if 0 <= i + adj_i < rows and 0 <= j + adj_j < cols:
neighbors[grid[i + adj_i][j + adj_j]] += 1
cell = grid[i][j]
if cell == "L" and neighbors["#"] == 0:
return "#"
elif cell == "#" and neighbors["#"] >= 4:
return "L"
else:
return cell
def evolution(grid: Grid) -> Grid:
return [
[evolve(grid, i, j) for j, c in enumerate(row)] for i, row in enumerate(grid)
]
def stabilize(grid: Grid) -> int:
while True:
g = evolution(grid)
if g == grid:
break
grid = g
return sum(c == "#" for row in grid for c in row)
def find_first_seat(grid: Grid, i: int, j: int, di: int, dj: int) -> str:
rows = len(grid)
cols = len(grid[0])
while True:
i += di
j += dj
if 0 <= i < rows and 0 <= j < cols:
if grid[i][j] == "#" or grid[i][j] == "L":
return grid[i][j]
else:
return "."
def evolve2(grid: Grid, i: int, j: int):
rows = len(grid)
cols = len(grid[0])
neighbors = {"#": 0, "L": 0, ".": 0}
for di, dj in adjacent:
first_seat = find_first_seat(grid, i, j, di, dj)
neighbors[first_seat] += 1
cell = grid[i][j]
if cell == "L" and neighbors["#"] == 0:
return "#"
elif cell == "#" and neighbors["#"] >= 5:
return "L"
else:
return cell
def evolution2(grid: Grid) -> Grid:
return [
[evolve2(grid, i, j) for j, c in enumerate(row)] for i, row in enumerate(grid)
]
def stabilize2(grid: Grid) -> int:
while True:
g = evolution2(grid)
if g == grid:
break
grid = g
return sum(c == "#" for row in grid for c in row)
# TESTS
RAW = """L.LL.LL.LL
LLLLLLL.LL
L.L.L..L..
LLLL.LL.LL
L.LL.LL.LL
L.LLLLL.LL
..L.L.....
LLLLLLLLLL
L.LLLLLL.L
L.LLLLL.LL"""
GRID = [list(row) for row in RAW.split("\n")]
print(stabilize(GRID))
pprint(stabilize2(GRID))
# REAL DATA
with open("inputs/day11.txt") as f:
data = [list(line.strip()) for line in f]
print(stabilize(data))
print(stabilize2(data))