Use trees crate
This commit is contained in:
parent
9b42768fdb
commit
ec5b46d793
|
@ -22,6 +22,7 @@ dependencies = [
|
||||||
"num",
|
"num",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"regex",
|
"regex",
|
||||||
|
"trees",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -340,6 +341,12 @@ dependencies = [
|
||||||
"winapi-util",
|
"winapi-util",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "trees"
|
||||||
|
version = "0.4.2"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "0de5f738ceab88e2491a94ddc33c3feeadfa95fedc60363ef110845df12f3878"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "winapi"
|
name = "winapi"
|
||||||
version = "0.3.9"
|
version = "0.3.9"
|
||||||
|
|
|
@ -13,6 +13,7 @@ env_logger = "^0.10"
|
||||||
num = "^0.1"
|
num = "^0.1"
|
||||||
lazy_static = "^1.4"
|
lazy_static = "^1.4"
|
||||||
once_cell = "^1.16"
|
once_cell = "^1.16"
|
||||||
|
trees = "^0.4"
|
||||||
|
|
||||||
[[bin]]
|
[[bin]]
|
||||||
name = "d1p1"
|
name = "d1p1"
|
||||||
|
|
|
@ -3,5 +3,5 @@ use aoc22::{day21, util};
|
||||||
pub fn main() {
|
pub fn main() {
|
||||||
let monkeys = day21::parse_monkeys(&util::parse_input());
|
let monkeys = day21::parse_monkeys(&util::parse_input());
|
||||||
|
|
||||||
println!("root yells: {}", day21::yell(&monkeys, "root"));
|
println!("root yells: {}", day21::yell(monkeys.root()));
|
||||||
}
|
}
|
||||||
|
|
47
src/day21.rs
47
src/day21.rs
|
@ -1,8 +1,9 @@
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
|
|
||||||
use regex::Regex;
|
use regex::Regex;
|
||||||
|
use trees::{tr, Node, Tree};
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
pub enum Operation {
|
pub enum Operation {
|
||||||
Add,
|
Add,
|
||||||
Sub,
|
Sub,
|
||||||
|
@ -22,14 +23,14 @@ impl Operation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug, Clone)]
|
||||||
pub enum Monkey {
|
pub enum Monkey {
|
||||||
Number(isize),
|
Number(isize),
|
||||||
Calculate(String, String, Operation),
|
Calculate(String, String, Operation),
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn parse_monkeys(input: &String) -> HashMap<String, Monkey> {
|
pub fn parse_monkeys(input: &String) -> Tree<Monkey> {
|
||||||
let mut result = HashMap::new();
|
let mut monkeys = HashMap::new();
|
||||||
|
|
||||||
let re = Regex::new(r"^(\w+): (?:(\d+)|(\w+) ([+\-*/]) (\w+))$").unwrap();
|
let re = Regex::new(r"^(\w+): (?:(\d+)|(\w+) ([+\-*/]) (\w+))$").unwrap();
|
||||||
for line in input.lines() {
|
for line in input.lines() {
|
||||||
|
@ -44,21 +45,39 @@ pub fn parse_monkeys(input: &String) -> HashMap<String, Monkey> {
|
||||||
Operation::from(captures.get(4).unwrap().as_str()),
|
Operation::from(captures.get(4).unwrap().as_str()),
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
result.insert(name.to_owned(), monkey);
|
monkeys.insert(name.to_owned(), monkey);
|
||||||
}
|
}
|
||||||
|
|
||||||
result
|
let tree = to_tree(&monkeys, "root");
|
||||||
|
|
||||||
|
tree
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn yell(monkeys: &HashMap<String, Monkey>, monkey: &str) -> isize {
|
fn to_tree(monkeys: &HashMap<String, Monkey>, monkey: &str) -> Tree<Monkey> {
|
||||||
let monkey = &monkeys[monkey];
|
let monkey = &monkeys[monkey];
|
||||||
match monkey {
|
let mut tree = tr(monkey.clone());
|
||||||
|
|
||||||
|
if let Monkey::Calculate(a, b, _) = monkey {
|
||||||
|
let forest = -to_tree(monkeys, a) - to_tree(monkeys, b);
|
||||||
|
tree.append(forest);
|
||||||
|
}
|
||||||
|
|
||||||
|
tree
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn yell(monkey: &Node<Monkey>) -> isize {
|
||||||
|
match monkey.data() {
|
||||||
Monkey::Number(n) => *n,
|
Monkey::Number(n) => *n,
|
||||||
Monkey::Calculate(a, b, op) => match op {
|
Monkey::Calculate(_, _, op) => {
|
||||||
Operation::Add => yell(monkeys, a) + yell(monkeys, b),
|
let mut children = monkey.iter();
|
||||||
Operation::Sub => yell(monkeys, a) - yell(monkeys, b),
|
let a = children.next().unwrap();
|
||||||
Operation::Mul => yell(monkeys, a) * yell(monkeys, b),
|
let b = children.next().unwrap();
|
||||||
Operation::Div => yell(monkeys, a) / yell(monkeys, b),
|
match op {
|
||||||
},
|
Operation::Add => yell(a) + yell(b),
|
||||||
|
Operation::Sub => yell(a) - yell(b),
|
||||||
|
Operation::Mul => yell(a) * yell(b),
|
||||||
|
Operation::Div => yell(a) / yell(b),
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue