mirror of
https://github.com/bertptrs/adventofcode.git
synced 2025-12-25 21:00:31 +01:00
Implement day 12 part 2
This commit is contained in:
@@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user