-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathday09.py
More file actions
71 lines (56 loc) · 1.69 KB
/
day09.py
File metadata and controls
71 lines (56 loc) · 1.69 KB
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
import itertools
import os
from typing import List
from aocd import get_data
from dotenv import load_dotenv
from utils import generate_readme
day = int(os.getcwd()[-2:])
year = int(os.getcwd()[-10:][:4])
def get_session() -> str:
load_dotenv()
return os.getenv('SESSION_COOKIE')
def run(data: str = None, part: int = None):
if not data:
if part == 1:
return part1(get_data(get_session(), day=day, year=year).splitlines())
else:
return part2(get_data(get_session(), day=day, year=year).splitlines())
else:
if part == 1:
return part1(data.splitlines())
else:
return part2(data.splitlines())
def calc(data: list, n: int = 125) -> int:
seen: List[int] = []
for i, line in enumerate(data):
if i >= n:
prev_25 = seen[-n:]
for x, y in itertools.combinations(prev_25, 2):
if x + y == int(line):
break
else:
return int(line)
seen.append(int(line))
raise NotImplementedError('unreachable')
def part1(data):
return calc(data)
def part2(data):
target = calc(data)
numbers = [int(line) for line in data]
start = 0
end = 0
current = numbers[0]
while True:
if current < target:
end += 1
current += numbers[end]
elif current > target:
current -= numbers[start]
start += 1
else:
r = numbers[start:end + 1]
return min(r) + max(r)
if __name__ == '__main__':
print(f'Part 1: {run(data=None, part=1)}')
print(f'Part 2: {run(data=None, part=2)}')
generate_readme("README", year, day, '../')