-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path11.py
87 lines (72 loc) · 2.28 KB
/
11.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
from itertools import chain
def adj(row, col, f):
for dr in [-1, 0, 1]:
cr = row + dr
if cr < 0 or cr >= len(f):
continue
for dc in [-1, 0, 1]:
if dr == 0 and dc == 0:
continue
cc = col + dc
if cc < 0 or cc >= len(f[cr]):
continue
yield f[cr][cc]
def star1():
f = [list(line.strip()) for line in open('input.txt')]
changed = True
while changed:
nf = [list(row) for row in f]
changed = False
for row in range(len(f)):
for col in range(len(f[0])):
occ = sum(1 for x in adj(row, col, f) if x == '#')
if f[row][col] == 'L' and occ == 0:
nf[row][col] = '#'
changed = True
elif f[row][col] == '#' and occ >= 4:
nf[row][col] = 'L'
changed = True
f = nf
print(sum(1 for c in chain.from_iterable(f) if c == '#'))
def star2():
f = [list(line.strip()) for line in open('input.txt')]
def infield(row, col):
return 0 <= row < len(f) and 0 <= col < len(f[0])
def find_occ(sr, sc, dr, dc):
cr, cc = sr, sc
while True:
cr += dr
cc += dc
if not infield(cr, cc):
return 0
if f[cr][cc] == 'L':
return 0
if f[cr][cc] == '#':
return 1
def count_occ(row, col):
result = 0
for dr in range(-1, 2):
for dc in range(-1, 2):
if dr == 0 and dc == 0:
continue
result += find_occ(row, col, dr, dc)
return result
changed = True
while changed:
changed = False
nf = [list(row) for row in f]
for row in range(len(f)):
for col in range(len(f[0])):
occ = count_occ(row, col)
if f[row][col] == 'L' and occ == 0:
nf[row][col] = '#'
changed = True
elif f[row][col] == '#' and occ >= 5:
nf[row][col] = 'L'
changed = True
f = nf
print(sum(sum(1 for c in row if c == '#') for row in f))
print('Star 1:')
star1()
print('Star 2:')
star2()