-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathday16.rs
53 lines (46 loc) · 1.54 KB
/
day16.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
//! # Aunt Sue
//!
//! Brute force search through each aunt until we find one that matches all the facts.
use crate::util::iter::*;
use crate::util::parse::*;
pub fn parse(input: &str) -> &str {
input
}
pub fn part1(input: &str) -> usize {
let predicate = |key: &str, value: &str| match key {
"akitas" | "vizslas" => value == "0",
"perfumes" => value == "1",
"samoyeds" | "cars" => value == "2",
"children" | "pomeranians" | "trees" => value == "3",
"goldfish" => value == "5",
"cats" => value == "7",
_ => unreachable!(),
};
solve(input, predicate)
}
pub fn part2(input: &str) -> usize {
let predicate = |key: &str, value: &str| match key {
"akitas" | "vizslas" => value == "0",
"perfumes" => value == "1",
"samoyeds" | "cars" => value == "2",
"children" => value == "3",
"pomeranians" => value.unsigned::<u32>() < 3,
"goldfish" => value.unsigned::<u32>() < 5,
"trees" => value.unsigned::<u32>() > 3,
"cats" => value.unsigned::<u32>() > 7,
_ => unreachable!(),
};
solve(input, predicate)
}
fn solve(input: &str, predicate: impl Fn(&str, &str) -> bool) -> usize {
'outer: for (index, line) in input.lines().enumerate() {
let tokens = line.split([' ', ':', ',']).filter(|s| !s.is_empty());
for [key, value] in tokens.chunk::<2>().skip(1) {
if !predicate(key, value) {
continue 'outer;
}
}
return index + 1;
}
unreachable!()
}