Compare commits
2 commits
78b8881016
...
37165b60fd
Author | SHA1 | Date | |
---|---|---|---|
37165b60fd | |||
1443834f4e |
7 changed files with 402 additions and 0 deletions
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
__pycache__
|
||||||
|
.direnv
|
||||||
|
venv
|
33
23/day5/example.txt
Normal file
33
23/day5/example.txt
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
seeds: 79 14 55 13
|
||||||
|
|
||||||
|
seed-to-soil map:
|
||||||
|
50 98 2
|
||||||
|
52 50 48
|
||||||
|
|
||||||
|
soil-to-fertilizer map:
|
||||||
|
0 15 37
|
||||||
|
37 52 2
|
||||||
|
39 0 15
|
||||||
|
|
||||||
|
fertilizer-to-water map:
|
||||||
|
49 53 8
|
||||||
|
0 11 42
|
||||||
|
42 0 7
|
||||||
|
57 7 4
|
||||||
|
|
||||||
|
water-to-light map:
|
||||||
|
88 18 7
|
||||||
|
18 25 70
|
||||||
|
|
||||||
|
light-to-temperature map:
|
||||||
|
45 77 23
|
||||||
|
81 45 19
|
||||||
|
68 64 13
|
||||||
|
|
||||||
|
temperature-to-humidity map:
|
||||||
|
0 69 1
|
||||||
|
1 0 69
|
||||||
|
|
||||||
|
humidity-to-location map:
|
||||||
|
60 56 37
|
||||||
|
56 93 4
|
219
23/day5/input.txt
Normal file
219
23/day5/input.txt
Normal file
|
@ -0,0 +1,219 @@
|
||||||
|
seeds: 2041142901 113138307 302673608 467797997 1787644422 208119536 143576771 99841043 4088720102 111819874 946418697 13450451 3459931852 262303791 2913410855 533641609 2178733435 26814354 1058342395 175406592
|
||||||
|
|
||||||
|
seed-to-soil map:
|
||||||
|
1270068015 1235603193 242614277
|
||||||
|
13415696 1478217470 21049126
|
||||||
|
825250550 1160341941 75261252
|
||||||
|
3786189027 1971702238 242038712
|
||||||
|
3191605340 3433644052 172752250
|
||||||
|
2389904665 3088515862 345128190
|
||||||
|
0 1499266596 13415696
|
||||||
|
1197451933 0 72616082
|
||||||
|
2139929050 1721726623 249975615
|
||||||
|
900511802 222541761 147014452
|
||||||
|
1047526254 72616082 149925679
|
||||||
|
34464822 980591812 179750129
|
||||||
|
2735032855 2631943377 456572485
|
||||||
|
3364357590 3606396302 421831437
|
||||||
|
214214951 369556213 611035599
|
||||||
|
1721726623 2213740950 418202427
|
||||||
|
|
||||||
|
soil-to-fertilizer map:
|
||||||
|
226793587 358613369 356867344
|
||||||
|
0 1838890301 226793587
|
||||||
|
2741010192 0 358613369
|
||||||
|
2257843811 715480713 173982825
|
||||||
|
3099623561 1264222741 3082010
|
||||||
|
1810570233 2912833547 326150077
|
||||||
|
4038242924 3815312886 256724372
|
||||||
|
2431826636 3268919687 279247493
|
||||||
|
866869902 1671637223 167253078
|
||||||
|
3102705571 889463538 374759203
|
||||||
|
1615333950 2646894858 125679350
|
||||||
|
2136720310 1550513722 121123501
|
||||||
|
3477464774 2772574208 140259339
|
||||||
|
1034122980 2065683888 581210970
|
||||||
|
2711074129 3238983624 29936063
|
||||||
|
583660931 1267304751 283208971
|
||||||
|
1741013300 3548167180 69556933
|
||||||
|
3815312886 4072037258 222930038
|
||||||
|
|
||||||
|
fertilizer-to-water map:
|
||||||
|
2197389106 1911800263 305927673
|
||||||
|
3117278994 244526473 20512291
|
||||||
|
2957263700 4069704360 136102838
|
||||||
|
1536592951 2749121858 245216219
|
||||||
|
3093366538 840656765 23912456
|
||||||
|
815267737 2718368501 30753357
|
||||||
|
3137791285 3392529258 82147206
|
||||||
|
3770129899 390297301 198889495
|
||||||
|
2168252150 2217727936 29136956
|
||||||
|
770420674 2367771416 44847063
|
||||||
|
3304122356 4205807198 44047643
|
||||||
|
94626393 318562852 71734449
|
||||||
|
2518697514 2262245627 10899396
|
||||||
|
1967704281 265038764 53524088
|
||||||
|
846021094 2994338077 264934624
|
||||||
|
1215514867 3881882833 187821527
|
||||||
|
1781809170 2556752263 100818318
|
||||||
|
1882627488 1690877042 85076793
|
||||||
|
208796777 631622731 209034034
|
||||||
|
2583608714 3508227847 39876494
|
||||||
|
519341481 1587040614 19652563
|
||||||
|
599791964 104559149 139967324
|
||||||
|
3430004623 1246915338 340125276
|
||||||
|
1110955718 0 104559149
|
||||||
|
2623485208 3548104341 333778492
|
||||||
|
1403336394 3259272701 133256557
|
||||||
|
0 2273145023 94626393
|
||||||
|
2529596910 1857788459 54011804
|
||||||
|
166360842 589186796 42435935
|
||||||
|
3219938491 1606693177 84183865
|
||||||
|
2165362153 3505337850 2889997
|
||||||
|
2021228369 2412618479 72557496
|
||||||
|
538994044 2657570581 60797920
|
||||||
|
739759288 3474676464 30661386
|
||||||
|
417830811 1154801218 92114120
|
||||||
|
509944931 864569221 9396550
|
||||||
|
2093785865 2485175975 71576288
|
||||||
|
3969019394 873965771 280835447
|
||||||
|
2503316779 2246864892 15380735
|
||||||
|
3348169999 1775953835 81834624
|
||||||
|
|
||||||
|
water-to-light map:
|
||||||
|
3059617387 1101868951 93963271
|
||||||
|
2772853640 2098642805 169363292
|
||||||
|
193287974 683814429 1482323
|
||||||
|
3780234682 1734000399 364642406
|
||||||
|
194770297 193287974 490526455
|
||||||
|
3550500423 902417243 199451708
|
||||||
|
3466829263 2268006097 83671160
|
||||||
|
3379471616 2976813583 87357647
|
||||||
|
2283311570 2369871058 489542070
|
||||||
|
3768145932 1195832222 12088750
|
||||||
|
1202605712 3064171230 1080705858
|
||||||
|
2942216932 2859413128 107440729
|
||||||
|
3749952131 2351677257 18193801
|
||||||
|
3049657661 2966853857 9959726
|
||||||
|
902417243 1433811930 300188469
|
||||||
|
3153580658 1207920972 225890958
|
||||||
|
|
||||||
|
light-to-temperature map:
|
||||||
|
1088722200 1345179841 10000894
|
||||||
|
4202170199 3029124889 92797097
|
||||||
|
3016749137 3130683307 53232372
|
||||||
|
534766220 331633133 9297796
|
||||||
|
190275035 286706851 44926282
|
||||||
|
3069981509 1355180735 96127340
|
||||||
|
1579189291 3913052943 379484702
|
||||||
|
3918942962 3793498681 21754451
|
||||||
|
262413801 377451173 88614642
|
||||||
|
2452226090 2443004441 143726844
|
||||||
|
1958673993 2586731285 188604820
|
||||||
|
2595952934 3815253132 97799811
|
||||||
|
882433672 754981589 206288528
|
||||||
|
608195463 3121921986 8761321
|
||||||
|
393888178 145828809 140878042
|
||||||
|
3166108849 1530740045 97835767
|
||||||
|
351028443 139489318 6339491
|
||||||
|
3410232629 961270117 222147493
|
||||||
|
2449796439 4292537645 2429651
|
||||||
|
2401067597 1890048598 48728842
|
||||||
|
3263944616 2376148398 66856043
|
||||||
|
3330800659 1451308075 79431970
|
||||||
|
3632380122 2019388074 205952206
|
||||||
|
1548873457 1323582243 21597598
|
||||||
|
2693752745 2225340280 142089882
|
||||||
|
357367934 340930929 36520244
|
||||||
|
0 493278299 50785717
|
||||||
|
768194739 645497224 68742488
|
||||||
|
2876584504 1183417610 140164633
|
||||||
|
235201317 466065815 27212484
|
||||||
|
1570471055 2367430162 8718236
|
||||||
|
2147278813 2775336105 253788784
|
||||||
|
874238988 3335153634 8194684
|
||||||
|
2835842627 714239712 40741877
|
||||||
|
3838332328 1938777440 80610634
|
||||||
|
50785717 0 139489318
|
||||||
|
616956784 3183915679 151237955
|
||||||
|
836937227 608195463 37301761
|
||||||
|
1098723094 3343348318 450150363
|
||||||
|
3940697413 1628575812 261472786
|
||||||
|
|
||||||
|
temperature-to-humidity map:
|
||||||
|
3865679795 3411240257 137388137
|
||||||
|
0 569718370 128927628
|
||||||
|
2284256983 1093255418 349419361
|
||||||
|
2189606444 2745948834 16886013
|
||||||
|
3861728218 3796217004 3951577
|
||||||
|
700036088 2134161201 67667679
|
||||||
|
2639129496 1078899666 14355752
|
||||||
|
4003067932 4146768977 27598493
|
||||||
|
569558723 2311178479 130477365
|
||||||
|
4125126694 3887925067 11822916
|
||||||
|
1884679865 1442674779 129657290
|
||||||
|
2633676344 1572332069 5453152
|
||||||
|
862461784 1577785221 531688422
|
||||||
|
4030666425 4120171499 26597478
|
||||||
|
195554894 115268399 39538402
|
||||||
|
235093296 235252943 334465427
|
||||||
|
2132287170 698645998 57319274
|
||||||
|
4158735055 3550090086 136232241
|
||||||
|
2206492457 157488417 77764526
|
||||||
|
3562496130 3899747983 220423516
|
||||||
|
2653485248 2201828880 109349599
|
||||||
|
2014337155 154806801 2681616
|
||||||
|
1580787383 2536413861 97415145
|
||||||
|
3453031511 3880534101 7390966
|
||||||
|
1394150206 2633829006 45492562
|
||||||
|
4057263903 3686322327 7821024
|
||||||
|
4157273363 3548628394 1461692
|
||||||
|
3460422477 3694143351 102073653
|
||||||
|
4136949610 3800168581 20323753
|
||||||
|
1678202528 872422329 206477337
|
||||||
|
1556099825 2109473643 24687558
|
||||||
|
128927628 2679321568 66627266
|
||||||
|
2017018771 0 115268399
|
||||||
|
4065084927 3820492334 60041767
|
||||||
|
3411240257 4253176042 41791254
|
||||||
|
767703767 2441655844 94758017
|
||||||
|
1439642768 755965272 116457057
|
||||||
|
3782919646 4174367470 78808572
|
||||||
|
|
||||||
|
humidity-to-location map:
|
||||||
|
347042062 4204488573 2962316
|
||||||
|
877642375 2878291222 23518224
|
||||||
|
3638916554 3484768713 5466055
|
||||||
|
2890676240 3280663590 83564486
|
||||||
|
201731623 3228655138 52008452
|
||||||
|
1692198890 1946017811 25211210
|
||||||
|
1717410100 1270737209 92827656
|
||||||
|
3598929376 3630765534 39987178
|
||||||
|
2226479211 1578430526 262844314
|
||||||
|
687169155 3670752712 117494406
|
||||||
|
3884728324 1515480569 62949957
|
||||||
|
3494186405 1841274840 104742971
|
||||||
|
2753482998 2630924017 120642845
|
||||||
|
572458731 2235388494 114710424
|
||||||
|
3947678281 3490234768 140530766
|
||||||
|
3433348031 3167816764 60838374
|
||||||
|
350004378 2406580589 222454353
|
||||||
|
804663561 1442501755 72978814
|
||||||
|
4132461733 2901809446 35781203
|
||||||
|
4088209047 2937590649 38937925
|
||||||
|
1441554453 2350098918 56481671
|
||||||
|
3644382609 201731623 240345715
|
||||||
|
2489323525 1971229021 264159473
|
||||||
|
2974240726 3086380958 81435806
|
||||||
|
4127146972 3364228076 5314761
|
||||||
|
901160599 4207450889 87516407
|
||||||
|
988677006 442077338 350976352
|
||||||
|
1498036124 3369542837 115225876
|
||||||
|
1810237756 3788247118 416241455
|
||||||
|
1613262000 1363564865 78936890
|
||||||
|
253740075 2993078971 93301987
|
||||||
|
3055676532 894954785 375782424
|
||||||
|
1339653358 793053690 101901095
|
||||||
|
2874125843 2976528574 16550397
|
||||||
|
3431458956 2629034942 1889075
|
||||||
|
4168242936 2751566862 126724360
|
85
23/day5/main.py
Executable file
85
23/day5/main.py
Executable file
|
@ -0,0 +1,85 @@
|
||||||
|
import math
|
||||||
|
|
||||||
|
seeds = []
|
||||||
|
mappings = {}
|
||||||
|
|
||||||
|
with open("input.txt", "r") as f:
|
||||||
|
current_map = None
|
||||||
|
for line in f:
|
||||||
|
line = line.strip()
|
||||||
|
if line == "":
|
||||||
|
continue
|
||||||
|
elif line.startswith("seeds:"):
|
||||||
|
seeds = list(map(int, line.removeprefix("seeds: ").split(" ")))
|
||||||
|
elif line.endswith(" map:"):
|
||||||
|
x, _, y = line.removesuffix(" map:").split("-")
|
||||||
|
current_map = (x, y)
|
||||||
|
mappings[x] = {"next": y, "maps": []}
|
||||||
|
else:
|
||||||
|
dest_start, src_start, length = list(map(int, line.split(" ")))
|
||||||
|
mappings[current_map[0]]["maps"].append((dest_start, src_start, length))
|
||||||
|
|
||||||
|
locations = []
|
||||||
|
|
||||||
|
for seed in seeds:
|
||||||
|
current_type = "seed"
|
||||||
|
current_number = seed
|
||||||
|
while current_type != "location":
|
||||||
|
mapping = mappings[current_type]
|
||||||
|
found_dest = None
|
||||||
|
for dest_start, src_start, length in mapping["maps"]:
|
||||||
|
if current_number in range(src_start, src_start + length):
|
||||||
|
found_dest = dest_start + (current_number - src_start)
|
||||||
|
break
|
||||||
|
if found_dest == None:
|
||||||
|
found_dest = current_number
|
||||||
|
|
||||||
|
current_type = mapping["next"]
|
||||||
|
current_number = found_dest
|
||||||
|
locations.append(current_number)
|
||||||
|
|
||||||
|
print("part1", min(locations))
|
||||||
|
|
||||||
|
|
||||||
|
def partition(lst, size):
|
||||||
|
for i in range(0, len(lst) // size):
|
||||||
|
yield lst[i::size]
|
||||||
|
|
||||||
|
|
||||||
|
# current_type = "seed"
|
||||||
|
# ranges = []
|
||||||
|
lowest = math.inf
|
||||||
|
|
||||||
|
first_seed = None
|
||||||
|
for seed in seeds:
|
||||||
|
if first_seed == None:
|
||||||
|
first_seed = seed
|
||||||
|
continue
|
||||||
|
second_seed = seed
|
||||||
|
|
||||||
|
print("Lezgo", first_seed, second_seed)
|
||||||
|
|
||||||
|
# ranges.append((first_seed, first_seed + second_seed))
|
||||||
|
|
||||||
|
for seed in range(first_seed, first_seed + second_seed):
|
||||||
|
# print((seed - first_seed) / second_seed * 100)
|
||||||
|
current_type = "seed"
|
||||||
|
current_number = seed
|
||||||
|
while current_type != "location":
|
||||||
|
mapping = mappings[current_type]
|
||||||
|
found_dest = None
|
||||||
|
for dest_start, src_start, length in mapping["maps"]:
|
||||||
|
if current_number in range(src_start, src_start + length):
|
||||||
|
found_dest = dest_start + (current_number - src_start)
|
||||||
|
break
|
||||||
|
if found_dest == None:
|
||||||
|
found_dest = current_number
|
||||||
|
|
||||||
|
current_type = mapping["next"]
|
||||||
|
current_number = found_dest
|
||||||
|
if current_number < lowest:
|
||||||
|
lowest = current_number
|
||||||
|
|
||||||
|
first_seed = None
|
||||||
|
|
||||||
|
print("part2", lowest)
|
2
23/day6/example.txt
Normal file
2
23/day6/example.txt
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
Time: 7 15 30
|
||||||
|
Distance: 9 40 200
|
2
23/day6/input.txt
Normal file
2
23/day6/input.txt
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
Time: 46 68 98 66
|
||||||
|
Distance: 358 1054 1807 1080
|
58
23/day6/main.py
Normal file
58
23/day6/main.py
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
import tqdm
|
||||||
|
import re
|
||||||
|
|
||||||
|
input = "input.txt"
|
||||||
|
|
||||||
|
times = []
|
||||||
|
distances = []
|
||||||
|
|
||||||
|
with open(input, "r") as f:
|
||||||
|
for line in f:
|
||||||
|
line = line.strip()
|
||||||
|
if line.startswith("Time"):
|
||||||
|
times = map(int, re.split("\\s+", line)[1:])
|
||||||
|
else:
|
||||||
|
distances = map(int, re.split("\\s+", line)[1:])
|
||||||
|
|
||||||
|
races = []
|
||||||
|
|
||||||
|
for time, distance in zip(times, distances):
|
||||||
|
races.append((time, distance))
|
||||||
|
|
||||||
|
part1 = 1
|
||||||
|
for time, record_distance in races:
|
||||||
|
record_beaten_times = 0
|
||||||
|
for time_held in range(time):
|
||||||
|
time_left = time - time_held
|
||||||
|
speed = time_held
|
||||||
|
|
||||||
|
distance = speed * time_left
|
||||||
|
|
||||||
|
if distance > record_distance:
|
||||||
|
record_beaten_times += 1
|
||||||
|
part1 *= record_beaten_times
|
||||||
|
|
||||||
|
print("part1", part1)
|
||||||
|
|
||||||
|
time = 0
|
||||||
|
record_distance = 0
|
||||||
|
|
||||||
|
with open(input, "r") as f:
|
||||||
|
for line in f:
|
||||||
|
line = line.strip()
|
||||||
|
if line.startswith("Time"):
|
||||||
|
time = int("".join(re.split("\\s+", line)[1:]))
|
||||||
|
else:
|
||||||
|
record_distance = int("".join(re.split("\\s+", line)[1:]))
|
||||||
|
|
||||||
|
print(time)
|
||||||
|
part2 = 0
|
||||||
|
for time_held in tqdm.tqdm(range(time)):
|
||||||
|
time_left = time - time_held
|
||||||
|
speed = time_held
|
||||||
|
|
||||||
|
distance = speed * time_left
|
||||||
|
|
||||||
|
if distance > record_distance:
|
||||||
|
part2 += 1
|
||||||
|
print("part2", part2)
|
Loading…
Reference in a new issue