-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathday04.rs
33 lines (28 loc) · 1.04 KB
/
day04.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
//! # Scratchcards
//!
//! Part two is a dynamic programming problem. Starting with 1 copy of each card we add the extra
//! number of copies to the number of following cards equal to the number of winning numbers.
use crate::util::parse::*;
pub fn parse(input: &str) -> Vec<usize> {
input
.lines()
.map(|line| {
// Numbers are at most 99 so we can use a fixed size array instead of a HashSet.
let mut found = [false; 100];
let (win, have) = line.split_once('|').unwrap();
win.iter_unsigned::<usize>().skip(1).for_each(|i| found[i] = true);
have.iter_unsigned::<usize>().filter(|&i| found[i]).count()
})
.collect()
}
pub fn part1(input: &[usize]) -> u32 {
input.iter().map(|&n| (1 << n) >> 1).sum()
}
pub fn part2(input: &[usize]) -> u32 {
// Start with a single copy of each card.
let mut copies = vec![1; input.len()];
for (i, &n) in input.iter().enumerate() {
(1..=n).for_each(|j| copies[i + j] += copies[i]);
}
copies.iter().sum()
}