Implement day 12 part 2

This commit is contained in:
2021-12-12 11:31:54 +01:00
parent 4d1fdd9cc0
commit 0897e2e907

View File

@@ -30,20 +30,30 @@ fn is_small(cave: &str) -> bool {
cave.chars().all(|c| c.is_ascii_lowercase()) cave.chars().all(|c| c.is_ascii_lowercase())
} }
fn dfs_routes<'a>(edges: &'a EdgeMap, route: &'_ mut Vec<&'a str>, pos: &'a str) -> usize { fn dfs_routes<'a>(
if is_small(pos) && route.contains(&pos) { edges: &'a EdgeMap,
return 0; route: &'_ mut Vec<&'a str>,
} pos: &'a str,
mut small_twice: bool,
if pos == "end" { ) -> usize {
return 1; match pos {
"end" => return 1,
"start" if !route.is_empty() => return 0,
pos if is_small(pos) && route.contains(&pos) => {
if small_twice {
small_twice = false;
} else {
return 0;
}
}
_ => (),
} }
route.push(pos); route.push(pos);
let routes = edges[pos] let routes = edges[pos]
.iter() .iter()
.map(|new_pos| dfs_routes(edges, route, new_pos)) .map(|new_pos| dfs_routes(edges, route, new_pos, small_twice))
.sum(); .sum();
route.pop(); route.pop();
@@ -51,15 +61,19 @@ fn dfs_routes<'a>(edges: &'a EdgeMap, route: &'_ mut Vec<&'a str>, pos: &'a str)
routes routes
} }
pub fn part1(input: &mut dyn Read) -> String { fn parts_common(input: &mut dyn Read, small_twice: bool) -> String {
let edges = read_edges(input); let edges = read_edges(input);
let mut route = Vec::new(); let mut route = Vec::new();
dfs_routes(&edges, &mut route, "start").to_string() dfs_routes(&edges, &mut route, "start", small_twice).to_string()
} }
pub fn part2(_input: &mut dyn Read) -> String { pub fn part1(input: &mut dyn Read) -> String {
todo!() parts_common(input, false)
}
pub fn part2(input: &mut dyn Read) -> String {
parts_common(input, true)
} }
#[cfg(test)] #[cfg(test)]
@@ -78,4 +92,11 @@ mod tests {
test_implementation(part1, SAMPLE2, 19); test_implementation(part1, SAMPLE2, 19);
test_implementation(part1, SAMPLE3, 226); test_implementation(part1, SAMPLE3, 226);
} }
#[test]
fn sample_part2() {
test_implementation(part2, SAMPLE1, 36);
test_implementation(part2, SAMPLE2, 103);
test_implementation(part2, SAMPLE3, 3509);
}
} }