day08 part 1
This commit is contained in:
1
input/day08.txt
Normal file
1
input/day08.txt
Normal file
File diff suppressed because one or more lines are too long
@@ -1,4 +1,4 @@
|
|||||||
fn main() {
|
fn main() {
|
||||||
aoc_2018::tasks::day07::task1();
|
aoc_2018::tasks::day08::task1();
|
||||||
// aoc_2018::tasks::day07::task2();
|
// aoc_2018::tasks::day08::task2();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ pub fn task1() {
|
|||||||
result.push(next);
|
result.push(next);
|
||||||
let newly_open: HashSet<char> = depends_on
|
let newly_open: HashSet<char> = depends_on
|
||||||
.iter()
|
.iter()
|
||||||
.filter(|(task, deps)| deps.iter().all(|dep| result.chars().any(|c| c == *dep)))
|
.filter(|(_task, deps)| deps.iter().all(|dep| result.chars().any(|c| c == *dep)))
|
||||||
.map(|(task, _)| *task)
|
.map(|(task, _)| *task)
|
||||||
.collect();
|
.collect();
|
||||||
open = open.union(&newly_open).map(|c| *c).collect();
|
open = open.union(&newly_open).map(|c| *c).collect();
|
||||||
|
|||||||
47
src/tasks/day08.rs
Normal file
47
src/tasks/day08.rs
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
use crate::utils;
|
||||||
|
|
||||||
|
pub fn task1() {
|
||||||
|
let input: Vec<usize> = utils::read_file("input/day08.txt")
|
||||||
|
.split(" ")
|
||||||
|
.map(|x| x.parse().unwrap())
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
let (tree, rest) = Node::extract_from(&input);
|
||||||
|
println!("Metadata sum: {}", tree.metadata_sum());
|
||||||
|
println!("rest: {:?}", rest);
|
||||||
|
}
|
||||||
|
|
||||||
|
struct Node {
|
||||||
|
metadata: Vec<usize>,
|
||||||
|
children: Vec<Node>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Node {
|
||||||
|
fn extract_from(input: &[usize]) -> (Self, &[usize]) {
|
||||||
|
let mut rest_input = &input[2..];
|
||||||
|
let mut num_children: usize = input[0];
|
||||||
|
let num_meta: usize = input[1];
|
||||||
|
let mut children = Vec::new();
|
||||||
|
while num_children > 0 {
|
||||||
|
let (node, rest) = Node::extract_from(&rest_input);
|
||||||
|
children.push(node);
|
||||||
|
rest_input = rest;
|
||||||
|
num_children -= 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
let metadata = rest_input[..num_meta].iter().map(|x| *x).collect();
|
||||||
|
(Node { metadata, children }, &rest_input[num_meta..])
|
||||||
|
}
|
||||||
|
|
||||||
|
fn metadata_sum(&self) -> usize {
|
||||||
|
self.metadata.iter().sum::<usize>()
|
||||||
|
+ self
|
||||||
|
.children
|
||||||
|
.iter()
|
||||||
|
.map(|child| {
|
||||||
|
let s: usize = child.metadata_sum().clone();
|
||||||
|
s
|
||||||
|
})
|
||||||
|
.sum::<usize>()
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -5,3 +5,4 @@ pub mod day04;
|
|||||||
pub mod day05;
|
pub mod day05;
|
||||||
pub mod day06;
|
pub mod day06;
|
||||||
pub mod day07;
|
pub mod day07;
|
||||||
|
pub mod day08;
|
||||||
|
|||||||
Reference in New Issue
Block a user