39 lines
968 B
Python
39 lines
968 B
Python
|
from pprint import pprint
|
||
|
|
||
|
with open('input.txt', 'r') as f:
|
||
|
raw = [x.strip() for x in f.readlines()]
|
||
|
initial_state = raw[0].split(' ')[-1]
|
||
|
rules = dict()
|
||
|
for rule in raw[2:]:
|
||
|
x, y = rule.split(' => ')
|
||
|
rules[x] = y
|
||
|
|
||
|
print(initial_state)
|
||
|
pprint(rules)
|
||
|
|
||
|
gens = 50000000000
|
||
|
|
||
|
start_idx = 0
|
||
|
state = initial_state
|
||
|
print(state)
|
||
|
for it in range(gens):
|
||
|
if it % 10000 == 0:
|
||
|
print('calc at', it, 'state len:', len(state), 'idx', start_idx)
|
||
|
print(state)
|
||
|
next = []
|
||
|
state = '....' + state + '....'
|
||
|
for i in range(2, len(state) - 2):
|
||
|
seq = state[i-2:i+3]
|
||
|
next.append(rules.get(seq) or '.')
|
||
|
start_idx -= 2
|
||
|
state = ''.join(next)
|
||
|
start_idx += len(state) - len(state.lstrip('.'))
|
||
|
state = state.strip('.')
|
||
|
# print(' ' * (start_idx + 20) + state, start_idx)
|
||
|
|
||
|
res = 0
|
||
|
for i, pot_val in enumerate(state):
|
||
|
pot_id = i + start_idx
|
||
|
if pot_val == '#':
|
||
|
res += pot_id
|
||
|
print(res)
|