2023 day 8 part 2 solved

master
kwout 1 year ago
parent 9e4cf3fbf5
commit e972ca6378
  1. 18
      2023/8.py

@ -1,3 +1,5 @@
from math import lcm
input = open("input.txt", 'r').read().splitlines() input = open("input.txt", 'r').read().splitlines()
instructions = input[0] instructions = input[0]
nodes = {l.split()[0]: (l.split()[2][1:-1], l.split()[3][:-1]) for l in input[2:]} nodes = {l.split()[0]: (l.split()[2][1:-1], l.split()[3][:-1]) for l in input[2:]}
@ -9,4 +11,18 @@ while node != 'ZZZ':
node = nodes[node][0] if instructions[steps % len(instructions)] == 'L' else nodes[node][1] node = nodes[node][0] if instructions[steps % len(instructions)] == 'L' else nodes[node][1]
steps += 1 steps += 1
print(steps)
nodeGhost = [n for n in nodes if n[-1] == 'A']
multiples = []
for n in nodeGhost:
stepsGhost = 0
nodeTemp = n
while nodeTemp[-1] != 'Z':
nodeTemp = nodes[nodeTemp][0] if instructions[stepsGhost % len(instructions)] == 'L' else nodes[nodeTemp][1]
stepsGhost += 1
multiples.append(stepsGhost)
print(steps)
print(lcm(*multiples))
Loading…
Cancel
Save