-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsolution_2021_06.rs
103 lines (81 loc) · 2.1 KB
/
solution_2021_06.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
use std::num::ParseIntError;
use advent_of_code_common::parsing::Error;
const DATA: &str = include_str!("../../resources/06.txt");
type FishCount = [usize; 9];
fn parse(data: &str) -> Result<FishCount, Error> {
let vec: Vec<usize> = data
.trim()
.split(',')
.map(str::parse)
.collect::<Result<Vec<_>, ParseIntError>>()
.map_err(|e| format!("{e}"))?;
let mut result = FishCount::default();
for x in vec {
result[x] += 1;
}
Ok(result)
}
// 0 comes from 1
// 1 comes from 2
// 2 comes from 3
// 3 comes from 4
// 4 comes from 5
// 5 comes from 6
// 6 comes from 7 and 0
// 7 comes from 8
// 8 comes from 0
fn next_day(fishes: &FishCount) -> FishCount {
let mut result = FishCount::default();
(0 ..= 8).for_each(|k| {
let value = match k {
6 => fishes[0] + fishes[7],
8 => fishes[0],
_ => fishes[k + 1],
};
result[k] = value;
});
result
}
fn fish_count(fishes: &FishCount) -> usize {
fishes.iter().sum()
}
fn solve(data: &str, days: u32) -> Result<usize, Error> {
let mut fishes = parse(data)?;
for idx in 0 .. days {
println!("{idx} {} {fishes:?}", fish_count(&fishes));
fishes = next_day(&fishes);
}
println!("{days} {} {fishes:?}", fish_count(&fishes));
Ok(fish_count(&fishes))
}
fn main() {
let result_1 = solve(DATA, 80);
println!("Part 1: {result_1:?}");
let result_2 = solve(DATA, 256);
println!("Part 2: {result_2:?}");
}
#[cfg(test)]
mod tests {
use super::*;
const TEST_DATA: &str = "3,4,3,1,2";
#[test]
fn test_solve_1_test_1() {
assert_eq!(solve(TEST_DATA, 18), Ok(26));
}
#[test]
fn test_solve_1_test_2() {
assert_eq!(solve(TEST_DATA, 80), Ok(5934));
}
#[test]
fn test_solve_1_real() {
assert_eq!(solve(DATA, 80), Ok(362_740));
}
#[test]
fn test_solve_2_test() {
assert_eq!(solve(TEST_DATA, 256), Ok(26_984_457_539));
}
#[test]
fn test_solve_2_real() {
assert_eq!(solve(DATA, 256), Ok(1_644_874_076_764));
}
}