day5: added
This commit is contained in:
parent
9489b63769
commit
6a830b5cb8
171
src/day5/1.rs
171
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<u64> = lines
|
||||
.next()
|
||||
.map(|x| x.split(' ').skip(1).map(|y| y.parse::<u64>().unwrap()))
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let seed_to_soil: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let soil_to_ferti: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let ferti_to_water: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let water_to_light: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let light_to_temp: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let temp_to_humidity: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
let humidity_to_loc: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().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);
|
||||
});
|
||||
}
|
||||
|
|
180
src/day5/2.rs
180
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<u64> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
let v: Vec<u64> = x
|
||||
.split(' ')
|
||||
.skip(1)
|
||||
.map(|y| y.parse::<u64>().unwrap())
|
||||
.collect();
|
||||
|
||||
v.chunks(2)
|
||||
.flat_map(|x| (x[0]..x[0] + x[1]).collect::<Vec<u64>>())
|
||||
.collect::<Vec<u64>>()
|
||||
})
|
||||
.unwrap();
|
||||
|
||||
let seed_to_soil: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let soil_to_ferti: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let ferti_to_water: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let water_to_light: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let light_to_temp: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
|
||||
let temp_to_humidity: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().unwrap()).collect();
|
||||
let size = y[2];
|
||||
|
||||
(y[1]..y[1] + size, y[0]..y[0] + size)
|
||||
})
|
||||
})
|
||||
.unwrap()
|
||||
.collect();
|
||||
let humidity_to_loc: Vec<(Range<u64>, Range<u64>)> = lines
|
||||
.next()
|
||||
.map(|x| {
|
||||
x.lines().skip(1).map(|line| {
|
||||
let y: Vec<u64> = line.split(' ').map(|y| y.parse::<u64>().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);
|
||||
});
|
||||
}
|
||||
|
|
197
src/day5/input.txt
Normal file
197
src/day5/input.txt
Normal file
|
@ -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
|
33
src/day5/sample.txt
Normal file
33
src/day5/sample.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
|
Loading…
Reference in New Issue
Block a user