-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathday_25.rs
79 lines (65 loc) · 1.86 KB
/
day_25.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
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
use std::collections::HashMap;
use common::{solution, Answer};
use petgraph::{graph::UnGraph, stable_graph::NodeIndex, Graph, Undirected};
use rustworkx_core::connectivity::stoer_wagner_min_cut;
solution!("Snowverload", 25);
fn part_a(input: &str) -> Answer {
let wires = parse(input);
let total = wires.wire.node_count();
let (len, side) = stoer_wagner_min_cut(&wires.wire, |_| Ok::<i32, ()>(1))
.unwrap()
.unwrap();
assert_eq!(len, 3);
((total - side.len()) * side.len()).into()
}
fn part_b(_input: &str) -> Answer {
Answer::Unimplemented
}
struct Wires<'a> {
wire: Graph<&'a str, (), Undirected>,
}
fn parse(input: &str) -> Wires {
let mut nodes = HashMap::new();
let mut wire = UnGraph::new_undirected();
fn get_node<'a>(
nodes: &mut HashMap<&'a str, NodeIndex>,
wire: &mut Graph<&'a str, (), Undirected>,
name: &'a str,
) -> NodeIndex {
*nodes.entry(name).or_insert_with(|| wire.add_node(name))
}
for line in input.lines() {
let mut parts = line.split(": ");
let key = parts.next().unwrap();
let values = parts.next().unwrap().split_whitespace();
let node = get_node(&mut nodes, &mut wire, key);
for value in values {
let value = get_node(&mut nodes, &mut wire, value);
wire.add_edge(node, value, ());
}
}
Wires { wire }
}
#[cfg(test)]
mod test {
use indoc::indoc;
const CASE: &str = indoc! {"
jqt: rhn xhk nvd
rsh: frs pzl lsr
xhk: hfx
cmg: qnr nvd lhk bvb
rhn: xhk bvb hfx
bvb: xhk hfx
pzl: lsr hfx nvd
qnr: nvd
ntq: jqt hfx bvb xhk
nvd: lhk
lsr: lhk
rzs: qnr cmg lsr rsh
frs: qnr lhk lsr
"};
#[test]
fn part_a() {
assert_eq!(super::part_a(CASE), 54.into());
}
}