-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathd04.rs
More file actions
92 lines (77 loc) · 2.34 KB
/
d04.rs
File metadata and controls
92 lines (77 loc) · 2.34 KB
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
use crate::Day;
pub struct Day04 {}
impl Day for Day04 {
fn year(&self) -> u16 {
2023
}
fn day(&self) -> u8 {
4
}
fn part_one(&self) -> String {
self.read_default_input()
.lines()
.map(count_card_winning_numbers)
.map(|matching_numbers_count| match matching_numbers_count {
0 => 0,
1 => 1,
n => 1 << (n - 1),
})
.sum::<i32>()
.to_string()
}
fn part_two(&self) -> String {
// (copies, winning_numbers_count)
let mut cards: Vec<(u64, usize)> = vec![];
for (idx, line) in self.read_default_input().lines().enumerate() {
let winning_numbers_count = count_card_winning_numbers(line);
match cards.get_mut(idx) {
Some(card) => {
card.0 += 1;
card.1 = winning_numbers_count;
}
None => cards.push((1, winning_numbers_count)),
}
for copy_idx in (idx + 1)..=(idx + winning_numbers_count) {
let current_card = cards[idx];
match cards.get_mut(copy_idx) {
Some(card) => card.0 += current_card.0,
None => cards.push((current_card.0, 0)),
}
}
}
cards.iter().map(|card| card.0).sum::<u64>().to_string()
}
}
fn intersection<T>(vec_1: &Vec<T>, vec_2: &Vec<T>) -> Vec<T>
where
T: Eq + Copy,
{
let mut vec_intersection = vec![];
for item_vec_1 in vec_1 {
for item_vec_2 in vec_2 {
if item_vec_1 == item_vec_2 {
vec_intersection.push(*item_vec_1);
}
}
}
vec_intersection
}
fn count_card_winning_numbers(card_str: &str) -> usize {
let [_, numbers]: [&str; 2] = card_str
.split(':')
.collect::<Vec<&str>>()
.try_into()
.unwrap();
let [winning_numbers, owned_numbers]: [Vec<u64>; 2] = numbers
.split('|')
.map(|numbers| {
numbers
.split_whitespace()
.map(|number| number.parse::<u64>().unwrap())
.collect::<Vec<u64>>()
})
.collect::<Vec<Vec<u64>>>()
.try_into()
.unwrap();
intersection(&winning_numbers, &owned_numbers).len()
}