-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAOC_Day15_Part1.py
36 lines (32 loc) · 1.11 KB
/
AOC_Day15_Part1.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
import copy
import math
import numpy as np
from itertools import product
StartingNumbers = [6,13,1,15,2,0]
Turn = 0
SpokenNumbers = {}
for i in range(0,2020):
# print(SpokenNumbers)
Turn += 1
if i < len(StartingNumbers):
NewNumber = StartingNumbers[i]
if NewNumber in SpokenNumbers.keys():
SpokenNumbers[NewNumber].append(Turn)
else:
SpokenNumbers[NewNumber] = [Turn]
else:
if len(SpokenNumbers[OldNumber]) == 1:
NewNumber = 0
if NewNumber in SpokenNumbers.keys():
SpokenNumbers[NewNumber].append(Turn)
else:
SpokenNumbers[NewNumber] = [Turn]
else:
print(SpokenNumbers[OldNumber][-1],SpokenNumbers[OldNumber][-2])
NewNumber = SpokenNumbers[OldNumber][-1]-SpokenNumbers[OldNumber][-2]
if NewNumber in SpokenNumbers.keys():
SpokenNumbers[NewNumber].append(Turn)
else:
SpokenNumbers[NewNumber] = [Turn]
OldNumber = NewNumber
print("Turn = ",Turn," number = ",NewNumber)