-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathday19.rs
46 lines (36 loc) · 1.44 KB
/
day19.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
//! # Medicine for Rudolph
//!
//! Part one is a brute force search and replace of every possibility.
//!
//! Part two uses the analysis from `askalski` provided on the
//! [Day 19 solution megathread](https://www.reddit.com/r/adventofcode/comments/3xflz8/day_19_solutions/).
use crate::util::hash::*;
type Input<'a> = (&'a str, Vec<(&'a str, &'a str)>);
pub fn parse(input: &str) -> Input<'_> {
let (replacements, molecule) = input.rsplit_once("\n\n").unwrap();
(molecule, replacements.lines().map(|line| line.split_once(" => ").unwrap()).collect())
}
pub fn part1(input: &Input<'_>) -> usize {
let (molecule, replacements) = input;
let mut distinct = FastSet::new();
for (from, to) in replacements {
for (start, _) in molecule.match_indices(from) {
let size = molecule.len() - from.len() + to.len();
let end = start + from.len();
let mut string = String::with_capacity(size);
string.push_str(&molecule[..start]);
string.push_str(to);
string.push_str(&molecule[end..]);
distinct.insert(string);
}
}
distinct.len()
}
pub fn part2(input: &Input<'_>) -> usize {
let (molecule, _) = input;
let elements = molecule.chars().filter(char::is_ascii_uppercase).count();
let rn = molecule.matches("Rn").count();
let ar = molecule.matches("Ar").count();
let y = molecule.matches('Y').count();
elements - ar - rn - 2 * y - 1
}