-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
48 lines (36 loc) · 1.77 KB
/
main.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
import re
with open('input.txt') as file:
lines = [line.split('\n') for line in file.read().split('\n\n')]
def create_map(type_lines, prev_ranges):
ranges = []
for line in type_lines[1:]:
to_dest_start, to_source_start, from_count = map(int, line.split())
ranges.append([to_dest_start, to_source_start, from_count])
broken_down_ranges = []
for from_start, from_count in prev_ranges:
while from_count > 0:
have_range_match = False
for to_dest_start, to_source_start, to_count in ranges:
if to_source_start <= from_start < (to_source_start + to_count):
have_range_match = True
can_fit = to_count - (from_start - to_source_start)
if can_fit > from_count:
broken_down_ranges.append([to_dest_start + (from_start - to_source_start), from_count])
from_count = 0
else:
broken_down_ranges.append([to_dest_start + (from_start - to_source_start), can_fit])
from_count -= can_fit
from_start += can_fit
break
if not have_range_match:
broken_down_ranges.append([from_start, from_count])
break
return broken_down_ranges
def solve(seeds_ranges):
current_map = create_map(lines[1], seeds_ranges)
for i in range(2, len(lines)):
current_map = create_map(lines[i], current_map)
return min(current_map, key=lambda x: x[0])[0]
SEEDS = list(map(int, re.findall(r'\d+', lines[0][0])))
print(solve([[seed, 1] for seed in SEEDS]))
print(solve([[SEEDS[i], SEEDS[i + 1]] for i in range(0, len(SEEDS), 2)]))