Add 2020/10
This commit is contained in:
parent
1a9abe8f95
commit
5db6b005f9
|
@ -0,0 +1,92 @@
|
|||
76
|
||||
51
|
||||
117
|
||||
97
|
||||
7
|
||||
77
|
||||
63
|
||||
18
|
||||
137
|
||||
10
|
||||
23
|
||||
14
|
||||
130
|
||||
131
|
||||
8
|
||||
91
|
||||
17
|
||||
29
|
||||
2
|
||||
36
|
||||
110
|
||||
35
|
||||
113
|
||||
30
|
||||
112
|
||||
61
|
||||
83
|
||||
122
|
||||
28
|
||||
75
|
||||
124
|
||||
82
|
||||
101
|
||||
135
|
||||
42
|
||||
44
|
||||
128
|
||||
32
|
||||
55
|
||||
85
|
||||
119
|
||||
114
|
||||
72
|
||||
111
|
||||
107
|
||||
123
|
||||
54
|
||||
3
|
||||
98
|
||||
96
|
||||
11
|
||||
62
|
||||
22
|
||||
49
|
||||
37
|
||||
1
|
||||
104
|
||||
43
|
||||
24
|
||||
31
|
||||
129
|
||||
69
|
||||
4
|
||||
21
|
||||
48
|
||||
39
|
||||
9
|
||||
38
|
||||
58
|
||||
125
|
||||
81
|
||||
89
|
||||
65
|
||||
90
|
||||
118
|
||||
64
|
||||
25
|
||||
138
|
||||
16
|
||||
78
|
||||
92
|
||||
102
|
||||
88
|
||||
95
|
||||
132
|
||||
47
|
||||
50
|
||||
15
|
||||
68
|
||||
84
|
||||
136
|
||||
103
|
|
@ -0,0 +1,125 @@
|
|||
#![feature(test)]
|
||||
extern crate test;
|
||||
use std::{env, iter};
|
||||
|
||||
use itertools::Itertools;
|
||||
|
||||
type Parsed = Vec<usize>;
|
||||
|
||||
fn read_input() -> String {
|
||||
std::fs::read_to_string(
|
||||
env::args()
|
||||
.nth(1)
|
||||
.filter(|n| n != "--bench")
|
||||
.unwrap_or(String::from("inputs/day10")),
|
||||
)
|
||||
.unwrap()
|
||||
}
|
||||
|
||||
fn parse_input(raw: &str) -> Parsed {
|
||||
let mut xs: Vec<usize> = raw.lines().map(|l| l.parse().unwrap()).collect();
|
||||
// faster than using sorted() directly on the iterator
|
||||
xs.sort_unstable();
|
||||
xs
|
||||
}
|
||||
|
||||
fn part1(input: &Parsed) -> (usize, usize) {
|
||||
iter::once(&0)
|
||||
.chain(input.iter())
|
||||
.tuple_windows()
|
||||
.fold((0, 1), |(one, three), (a, b)| match b - a {
|
||||
1 => (one + 1, three),
|
||||
2 => (one, three),
|
||||
3 => (one, three + 1),
|
||||
_ => unreachable!(),
|
||||
})
|
||||
}
|
||||
|
||||
fn part2(input: &Parsed) -> usize {
|
||||
let max = *input.last().unwrap();
|
||||
let mut paths = vec![0; max + 4];
|
||||
paths[max] = 1;
|
||||
for i in input.iter().rev().skip(1) {
|
||||
let mut n = 0;
|
||||
for j in 1..=3 {
|
||||
n += paths[i + j];
|
||||
}
|
||||
paths[*i] = n;
|
||||
}
|
||||
paths[1] + paths[2] + paths[3]
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let input = parse_input(&read_input());
|
||||
let (ones, threes) = part1(&input);
|
||||
println!("Part 1: {}", ones * threes);
|
||||
println!("Part 2: {}", part2(&input));
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use super::*;
|
||||
use test::black_box;
|
||||
|
||||
const TEST_INPUT: &str = "28
|
||||
33
|
||||
18
|
||||
42
|
||||
31
|
||||
14
|
||||
46
|
||||
20
|
||||
48
|
||||
47
|
||||
24
|
||||
23
|
||||
49
|
||||
45
|
||||
19
|
||||
38
|
||||
39
|
||||
11
|
||||
1
|
||||
32
|
||||
25
|
||||
35
|
||||
8
|
||||
17
|
||||
7
|
||||
9
|
||||
4
|
||||
2
|
||||
34
|
||||
10
|
||||
3";
|
||||
|
||||
#[test]
|
||||
fn part1_test() {
|
||||
let input = parse_input(TEST_INPUT);
|
||||
assert_eq!(part1(&input), (22, 10));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn part2_test() {
|
||||
let input = parse_input(TEST_INPUT);
|
||||
assert_eq!(part2(&input), 19208);
|
||||
}
|
||||
|
||||
#[bench]
|
||||
fn bench_input_parsing(b: &mut test::Bencher) {
|
||||
let raw = read_input();
|
||||
b.iter(|| parse_input(black_box(&raw)))
|
||||
}
|
||||
|
||||
#[bench]
|
||||
fn bench_part1(b: &mut test::Bencher) {
|
||||
let input = parse_input(&read_input());
|
||||
b.iter(|| assert_eq!(part1(black_box(&input)), (69, 24)));
|
||||
}
|
||||
|
||||
#[bench]
|
||||
fn bench_part2(b: &mut test::Bencher) {
|
||||
let input = parse_input(&read_input());
|
||||
b.iter(|| assert_eq!(part2(black_box(&input)), 56693912375296));
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user