Compare commits

...

2 commits

Author SHA1 Message Date
37165b60fd day 6 2023-12-06 06:24:30 +01:00
1443834f4e 2023 day 5 2023-12-05 15:24:19 +01:00
7 changed files with 402 additions and 0 deletions

3
.gitignore vendored Normal file
View file

@ -0,0 +1,3 @@
__pycache__
.direnv
venv

33
23/day5/example.txt Normal file
View 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
View 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
View 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
View file

@ -0,0 +1,2 @@
Time: 7 15 30
Distance: 9 40 200

2
23/day6/input.txt Normal file
View file

@ -0,0 +1,2 @@
Time: 46 68 98 66
Distance: 358 1054 1807 1080

58
23/day6/main.py Normal file
View 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)