-
Notifications
You must be signed in to change notification settings - Fork 2
/
day04.py
49 lines (39 loc) · 966 Bytes
/
day04.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
from benchy import minibench
lines = open("day04.txt").read().split("\n")
games = []
def parse():
games.clear()
for id, line in enumerate(lines):
line = line.replace(" ", " ")
(_, t) = line.split(": ")
(a, b) = t.split(" | ")
n1 = set(map(int, a.split(" ")))
n2 = list(map(int, b.split(" ")))
games.append((id, n1, n2))
return 0
def part1():
s = 0
for _, win, hand in games:
c = 1
for num in hand:
if num in win:
c *= 2
s += c // 2
return s
def part2():
l = len(games)
w = [1] * l
s2 = 0
for id, win, hand in games:
x = 0
for num in hand:
if num in win:
x += 1
for i in range(id + 1, min(l, id + x + 1)):
w[i] += w[id]
s2 += w[id]
return s2
parse()
print(part1())
print(part2())
minibench({"parse": parse, "part1": part1, "part2": part2})