From 6a830b5cb8feb852b2f0f87e251444815d0814fc Mon Sep 17 00:00:00 2001 From: Ishan Jain Date: Tue, 5 Dec 2023 11:28:56 +0530 Subject: [PATCH] day5: added --- src/day5/1.rs | 171 +++++++++++++++++++++++++++++++++++++- src/day5/2.rs | 180 +++++++++++++++++++++++++++++++++++++++- src/day5/input.txt | 197 ++++++++++++++++++++++++++++++++++++++++++++ src/day5/sample.txt | 33 ++++++++ 4 files changed, 579 insertions(+), 2 deletions(-) create mode 100644 src/day5/input.txt create mode 100644 src/day5/sample.txt diff --git a/src/day5/1.rs b/src/day5/1.rs index b51073e..54a663b 100644 --- a/src/day5/1.rs +++ b/src/day5/1.rs @@ -1 +1,170 @@ -const INPUTS: [&'static str; 2] = [include_str!("./sample.txt"), include_str!("./input.txt")]; +#![feature(slice_split_once)] +#![feature(test)] + +use std::ops::Range; + +extern crate test; + +const INPUTS: [&str; 2] = [include_str!("./sample.txt"), include_str!("./input.txt")]; + +fn process(data: &str) -> u64 { + let mut lines = data.split("\n\n"); + + let seeds: Vec = lines + .next() + .map(|x| x.split(' ').skip(1).map(|y| y.parse::().unwrap())) + .unwrap() + .collect(); + + let seed_to_soil: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let soil_to_ferti: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let ferti_to_water: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let water_to_light: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let light_to_temp: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let temp_to_humidity: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + let humidity_to_loc: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let mut answer = std::u64::MAX; + + for seed in seeds { + let soil = seed_to_soil + .iter() + .find(|x| x.0.contains(&seed)) + .map(|x| seed + x.1.start - x.0.start) + .unwrap_or(seed); + + let ferti = soil_to_ferti + .iter() + .find(|x| x.0.contains(&soil)) + .map(|x| soil + x.1.start - x.0.start) + .unwrap_or(soil); + + let water = ferti_to_water + .iter() + .find(|x| x.0.contains(&ferti)) + .map(|x| ferti + x.1.start - x.0.start) + .unwrap_or(ferti); + + let light = water_to_light + .iter() + .find(|x| x.0.contains(&water)) + .map(|x| water + x.1.start - x.0.start) + .unwrap_or(water); + + let temp = light_to_temp + .iter() + .find(|x| x.0.contains(&light)) + .map(|x| light + x.1.start - x.0.start) + .unwrap_or(light); + let humidity = temp_to_humidity + .iter() + .find(|x| x.0.contains(&temp)) + .map(|x| temp + x.1.start - x.0.start) + .unwrap_or(temp); + let loc = humidity_to_loc + .iter() + .find(|x| x.0.contains(&humidity)) + .map(|x| humidity + x.1.start - x.0.start) + .unwrap_or(humidity); + + answer = std::cmp::min(answer, loc); + } + + answer +} + +fn main() { + for input in INPUTS.iter() { + println!("total = {}", process(input)); + } +} + +#[bench] +fn part1(b: &mut test::Bencher) { + b.iter(|| { + let v = process(INPUTS[1]); + test::black_box(v); + }); +} diff --git a/src/day5/2.rs b/src/day5/2.rs index b51073e..5a809a3 100644 --- a/src/day5/2.rs +++ b/src/day5/2.rs @@ -1 +1,179 @@ -const INPUTS: [&'static str; 2] = [include_str!("./sample.txt"), include_str!("./input.txt")]; +#![feature(slice_split_once)] +#![feature(test)] + +use std::ops::Range; + +extern crate test; + +const INPUTS: [&str; 2] = [include_str!("./sample.txt"), include_str!("./input.txt")]; + +fn process(data: &str) -> u64 { + let mut lines = data.split("\n\n"); + + let seeds: Vec = lines + .next() + .map(|x| { + let v: Vec = x + .split(' ') + .skip(1) + .map(|y| y.parse::().unwrap()) + .collect(); + + v.chunks(2) + .flat_map(|x| (x[0]..x[0] + x[1]).collect::>()) + .collect::>() + }) + .unwrap(); + + let seed_to_soil: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let soil_to_ferti: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let ferti_to_water: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let water_to_light: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let light_to_temp: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let temp_to_humidity: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + let humidity_to_loc: Vec<(Range, Range)> = lines + .next() + .map(|x| { + x.lines().skip(1).map(|line| { + let y: Vec = line.split(' ').map(|y| y.parse::().unwrap()).collect(); + let size = y[2]; + + (y[1]..y[1] + size, y[0]..y[0] + size) + }) + }) + .unwrap() + .collect(); + + let mut answer = std::u64::MAX; + + for seed in seeds { + let soil = seed_to_soil + .iter() + .find(|x| x.0.contains(&seed)) + .map(|x| seed + x.1.start - x.0.start) + .unwrap_or(seed); + + let ferti = soil_to_ferti + .iter() + .find(|x| x.0.contains(&soil)) + .map(|x| soil + x.1.start - x.0.start) + .unwrap_or(soil); + + let water = ferti_to_water + .iter() + .find(|x| x.0.contains(&ferti)) + .map(|x| ferti + x.1.start - x.0.start) + .unwrap_or(ferti); + + let light = water_to_light + .iter() + .find(|x| x.0.contains(&water)) + .map(|x| water + x.1.start - x.0.start) + .unwrap_or(water); + + let temp = light_to_temp + .iter() + .find(|x| x.0.contains(&light)) + .map(|x| light + x.1.start - x.0.start) + .unwrap_or(light); + let humidity = temp_to_humidity + .iter() + .find(|x| x.0.contains(&temp)) + .map(|x| temp + x.1.start - x.0.start) + .unwrap_or(temp); + let loc = humidity_to_loc + .iter() + .find(|x| x.0.contains(&humidity)) + .map(|x| humidity + x.1.start - x.0.start) + .unwrap_or(humidity); + + answer = std::cmp::min(answer, loc); + } + + answer +} + +fn main() { + for input in INPUTS.iter() { + println!("total = {}", process(input)); + } +} + +#[bench] +fn part1(b: &mut test::Bencher) { + b.iter(|| { + let v = process(INPUTS[1]); + test::black_box(v); + }); +} diff --git a/src/day5/input.txt b/src/day5/input.txt new file mode 100644 index 0000000..2fb1f85 --- /dev/null +++ b/src/day5/input.txt @@ -0,0 +1,197 @@ +seeds: 3082872446 316680412 2769223903 74043323 4131958457 99539464 109726392 353536902 619902767 648714498 3762874676 148318192 1545670780 343889780 4259893555 6139816 3980757676 20172062 2199623551 196958359 + +seed-to-soil map: +2211745924 1281207339 39747980 +3648083739 2564129012 145170114 +4171944574 2333022880 44675857 +540694760 848661020 78793182 +256996824 588160543 260500477 +1870557289 1804847051 174857657 +3877597859 2853012070 228980636 +1634159465 2150723562 100770342 +3793253853 2293912908 39109972 +652571990 567856215 20304328 +2480343183 3372556760 130573730 +1831144195 528443121 39413094 +0 1690920197 113926854 +3145720856 3081992706 290564054 +624623106 1979704708 27948884 +3844601856 3751059243 32996003 +1260492360 1175075910 106131429 +1366623789 166330978 138490835 +1175000149 927454202 85492211 +696570061 1596389312 94530885 +2647046837 3784055246 498674019 +4216620431 2709299126 78346865 +953230443 1450000160 146389152 +791100946 1012946413 162129497 +1734929807 427093569 96214388 +672876318 403399826 23693743 +113926854 2007653592 143069970 +2045414946 0 166330978 +1099619595 328019272 75380554 +3832363825 4282729265 12238031 +619487942 523307957 5135164 +517497301 304821813 23197459 +2293912908 2377698737 186430275 +1505114624 1320955319 129044841 +2610916913 3714929319 36129924 +3436284910 3503130490 211798829 +4106578495 2787645991 65366079 + +soil-to-fertilizer map: +2733576308 471599794 76965554 +1171423854 1329782324 37554133 +2640052871 928987130 93523437 +2015828352 548565348 204028986 +3562821857 3651707516 643259780 +1208977987 2596877127 12575372 +778871551 2204324824 392552303 +1221553359 2609452499 201089363 +3520687457 3069361301 42134400 +4240454288 3542205804 54513008 +2219857338 1367336457 420195533 +3034988650 3111495701 430710103 +307271757 0 471599794 +1422642722 2082393746 121931078 +3465698753 3596718812 54988704 +0 1022510567 307271757 +1544573800 1787531990 294861756 +4206081637 3034988650 34372651 +1839435556 752594334 176392796 + +fertilizer-to-water map: +1807260819 3957534991 337432305 +774926879 2718324291 701236360 +2351569884 1690420176 794087185 +313174888 2484507361 233816930 +3145657069 541109949 949949029 +546991818 313174888 227935061 +2144693124 3750658231 206876760 +4095606098 1491058978 199361198 +1476163239 3419560651 331097580 + +water-to-light map: +3834982820 3688486185 202897824 +2016707141 372287565 116618935 +3386838019 3412408553 81116937 +1125723906 705568567 205087174 +4037880644 1840142480 150018623 +2359176858 4109550629 126312910 +3328178239 4050890849 58659780 +1801115923 3893484758 43944958 +1516002989 1645262885 194879595 +3501845456 488906500 216662067 +1373868013 2223115169 142134976 +3467954956 3641943956 33890500 +1845060881 3937429716 113461133 +3718507523 910655741 57371540 +3315526510 3675834456 12651729 +2936874590 2031117287 84929853 +1710882584 3551710617 90233339 +372287565 2365250145 753436341 +2133326076 968027281 225850782 +1330811080 1990161103 40956184 +1958522014 3493525490 58185127 +3021804443 3118686486 293722067 +2485489768 1193878063 451384822 +3775879063 4235863539 59103757 +1371767264 3891384009 2100749 +4187899267 2116047140 107068029 + +light-to-temperature map: +156743496 2059819668 37694357 +4058204935 4136802755 38991573 +2484168315 1803830764 54458297 +2053264847 2531370441 7735546 +586814267 2539105987 96956250 +2538626612 2097514025 117228608 +4097196508 3782742182 197770788 +1246999413 607900903 25957627 +1877009740 1752361784 30081637 +683770517 3121708332 89729874 +1835387899 343006762 41621841 +1806332066 3242032508 29055833 +2212907940 137512351 205494411 +809588378 2954088675 69458905 +1689902424 3271088341 436818 +3306521233 894737794 308504080 +3235066415 3050253514 71454818 +1147299995 1960120250 99699418 +2046683718 749851354 6581129 +3782742182 4222506720 5456115 +2061000393 756432483 138305311 +792839631 591152156 16748747 +1478425864 2742612115 211476560 +2793367571 2636062237 73608402 +2471831801 2214742633 12336514 +194437853 1622309324 130052460 +3901915150 3980512970 156289785 +2655855220 0 137512351 +324490313 1359985370 262323954 +3855202758 4175794328 46712392 +2445108285 1782443421 21387343 +2467550357 3211438206 4281444 +3788198297 4227962835 67004461 +2199305704 2709670639 13602236 +1272957040 385683332 205468824 +1690339242 633858530 115992824 +1907091377 2227079147 139592341 +0 1203241874 156743496 +2866975973 1858289061 24590288 +1120987137 3215719650 26312858 +2891566261 3271525159 343500154 +2466495628 384628603 1054729 +1043746236 1882879349 77240901 +879047283 2366671488 164698953 +773500391 2723272875 19339240 +2418402351 3023547580 26705934 + +temperature-to-humidity map: +159374282 333555332 155635040 +2263203984 507165487 202752561 +1337996197 836383358 269347352 +733930089 139752127 104367475 +2840449774 3878218681 416748615 +3373626730 3111757526 416998602 +3943881399 2795875886 241056063 +3790625332 2642619819 153256067 +3298801153 3036931949 30341941 +1671783850 1980182260 485774285 +0 313933177 19622155 +2642619819 3680388726 197829955 +2157558135 1398186167 105645849 +4283100212 3528756128 11867084 +843670838 1503832016 347905328 +1607343549 244119602 64440301 +315009322 709918048 126465310 +441474632 1105730710 292455457 +3257198389 3540623212 41602764 +838297564 308559903 5373274 +1320021082 489190372 17975115 +4184937462 3582225976 98162750 +1191576166 1851737344 128444916 +3329143094 3067273890 44483636 +19622155 0 139752127 + +humidity-to-location map: +3728200417 3220538748 36833684 +1907946842 1065499951 70751518 +1978698360 2011387412 298481649 +4048923771 3541262102 246043525 +1314245652 402299218 396512619 +577039234 798811837 266688114 +3249926596 2795059130 273974120 +1734859977 229212353 173086865 +2718652009 3787305627 454867466 +1710758271 1405898165 24101706 +843727348 1510857580 66114574 +3765034101 3257372432 283889670 +1179488618 1876630378 134757034 +909841922 1136251469 269646696 +3675406214 4242173093 52794203 +310070062 1576972154 266969172 +229212353 1429999871 80857709 +3523900716 3069033250 151505498 +3173519475 2718652009 76407121 +2277180009 1843941326 32689052 diff --git a/src/day5/sample.txt b/src/day5/sample.txt new file mode 100644 index 0000000..bd902a4 --- /dev/null +++ b/src/day5/sample.txt @@ -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 \ No newline at end of file