Compare commits

..

No commits in common. "ae4332c7d3ab41c8fed6866ed87e354bbbec283b" and "b38cb21b02398cc7ba63d98980746ece738c36f4" have entirely different histories.

6 changed files with 79 additions and 258 deletions

View File

@ -4,7 +4,8 @@ use std::path::Path;
pub fn read_file(name: &str) -> String { pub fn read_file(name: &str) -> String {
let path = Path::new("src").join(name).join("input.txt"); let path = Path::new("src").join(name).join("input.txt");
let mut file = File::open(&path).expect(&format!("Unable to open input for '{name}'.")); let mut file = File::open(&path)
.expect(&format!("Unable to open input for '{name}'."));
let mut contents = String::new(); let mut contents = String::new();
file.read_to_string(&mut contents) file.read_to_string(&mut contents)

View File

@ -8,22 +8,23 @@ pub fn split_lines(input: &str) -> Vec<String> {
.collect() .collect()
} }
pub fn match_input(entry: &str, re: &str) -> Vec<String> { pub fn split_input(entry: &str, re: &str) -> Vec<String> {
let regex = Regex::new(re).expect("Invalid regex provided!"); let regex = Regex::new(re)
.expect("Invalid regex");
let matches: Vec<String> = regex let split: Vec<String> = regex
.find_iter(entry) .split(entry)
.map(|m| m.as_str().to_string()) .map(|s| s.to_string())
.collect(); .collect();
matches split
} }
pub fn match_inputs(input: Vec<String>, re: &str) -> Vec<Vec<String>> { pub fn split_inputs(input: Vec<String>, re: &str) -> Vec<Vec<String>> {
let mut result = Vec::new(); let mut result = Vec::new();
for entry in input { for entry in input {
let split = match_input(&entry, re); let split = split_input(&entry, re);
result.push(split); result.push(split);
} }
@ -34,13 +35,13 @@ pub fn convert_num(input: Vec<Vec<String>>) -> Vec<Vec<i32>> {
input input
.into_iter() .into_iter()
.map(|a| { .map(|a| {
a.into_iter() a
.into_iter()
.map(|b| { .map(|b| {
b.trim() b
.parse::<i32>() .trim()
.parse::<i32>()
.expect("Invalid numeric value in input!") .expect("Invalid numeric value in input!")
}) }).collect()
.collect() }).collect()
})
.collect()
} }

View File

@ -1,4 +1,4 @@
use crate::common::{convert_num, match_inputs, read_file, split_lines}; use crate::common::{convert_num, read_file, split_inputs, split_lines};
#[allow(dead_code)] #[allow(dead_code)]
pub fn part_two() { pub fn part_two() {
@ -18,35 +18,72 @@ fn predict(forward: bool) {
let current = s.to_vec(); let current = s.to_vec();
let mut next = extra_diff(current); let mut next = extra_diff(current);
expand(&mut next, forward); expand(&mut next, forward);
let history = next.first().unwrap(); let history = next
.first()
.unwrap();
if forward { if forward {
history.last().unwrap().clone() history
.last()
.unwrap()
.clone()
} else { } else {
history.first().unwrap().clone() history
.first()
.unwrap()
.clone()
} }
}) })
.collect(); .collect();
let sum: i32 = predictions.iter().sum(); let sum: i32 = predictions
.iter()
.sum();
println!("The sum of all prediction values is: '{sum}'."); println!("The sum of all prediction values is: '{sum}'.");
} }
fn expand(strct: &mut Vec<Vec<i32>>, forward: bool) { fn expand(strct: &mut Vec<Vec<i32>>, forward: bool) {
let last = strct.last_mut().unwrap(); let last = strct
last.push(*last.last().unwrap()); .last_mut()
.unwrap();
last.push(*last
.last()
.unwrap()
);
for i in (0..strct.len() - 1).rev() { for i in (0..strct.len() - 1).rev() {
let last = strct.get(i + 1).unwrap().clone(); let last = strct
let current = strct.get_mut(i).unwrap(); .get(i + 1)
.unwrap()
.clone();
let current = strct
.get_mut(i)
.unwrap();
if forward { if forward {
current.push(current.last().unwrap().clone() + last.last().unwrap().clone()); current.push(
current
.last()
.unwrap()
.clone() +
last
.last()
.unwrap()
.clone()
);
} else { } else {
current.insert( current.insert(
0, 0,
current.first().unwrap().clone() - last.first().unwrap().clone(), current
.first()
.unwrap()
.clone() -
last
.first()
.unwrap()
.clone()
); );
} }
} }
@ -85,6 +122,6 @@ fn setup() -> Vec<Vec<i32>> {
let content = read_file(name); let content = read_file(name);
let lines = split_lines(&content); let lines = split_lines(&content);
let input = match_inputs(lines, &r"\s*-?\d+\s*"); let input = split_inputs(lines, &r"\s+");
convert_num(input) convert_num(input)
} }

View File

@ -1,140 +0,0 @@
..#............................#....................................................................................#..........#........#...
..........#.........................................#.......................................................................................
...................#..........................................................................#.............................................
.....................................................................................#.............................................#........
.......#.......#.............#..........#......#...................#.....#..................................................................
................................................................................#..................#..............#.........................
....................................#.......................................................................................................
...........#...................................................................................#......................................#.....
.......................................................................................................................#.........#..........
.....................#.................................................#...................#.................#..............#...............
....#...........................................#...............#...........................................................................
.........................#.......................................................................#..........................................
...................................#......................#.......................................................#.......................#.
..................#...........................................................#.......................#.................#...........#.......
..........#........................................................#..........................................#.............................
.............................................#.........#.....#..............................................................................
.......................#.....................................................................#..............................#..........#....
.............................#.......................................................#...........................#..........................
..#...........#.......................#.....................................#...............................................................
...........................................................#.............................................#..................................
......#..........................................................#......#........................................................#..........
................................#.........#...........#....................................#........#...................#..................#
...........................#..................................................#..............................#..............................
..............................................#.................................................#...........................................
.#.................................................................................................................#........................
.......................................................................#....................................................................
...............#.............................................................................................................#..........#...
.................................#.............................#............................................#...............................
.....#.................#...................#................................................................................................
....................................................#...................................................#............#......................
...........#.....#...................................................................#............................................#.........
..............................................#...........................................................................#.................
...#.........................#.....................................................................#........................................
.........................................................#...................................#........................................#.....
.........#....................................................#........#................#.....................#.............................
........................#..........................................................................................#........................
..............#...................................#............................#.............................................#.....#........
.................................#................................................................#.........................................
..................#........................#...............#................................#.............#.............................#...
..........#........................................................#............................................................#...........
..#.....................................................................................#.............................#.....................
..........................#..........#..................................#......................................#...........#................
................................................................#...........................................................................
................#................................#..........................#...............................................................
...........................................#..................................................#.....#.......#...............................
..........#............................................#.....................................................................#..............
.......................#....................................#...........................................................#..............#....
.....#.........................#........#..............................................#.................#........................#.........
.................#....................................................#............................................#........................
....................................#...............#................................................#......................................
.........................#........................................#................#.......#...................#............................
....................................................................................................................................#.......
...........#...................................#...........................#......................#.........................#..............#
..................................#......#..................................................................................................
......#....................#.........................#..................................................#...................................
......................#...................................#......#.....#.................................................#..................
..............#..............................................................................#.................#.....................#......
............................................................................................................................................
#.............................#................#....................................................................#....................#..
............................................................................................................................................
........#...........................................#.......................................................................................
...................................................................#..........#..................#..........................................
.....................#............#........#.............................................#............#................#....................
................#............................................................................................................#..............
...............................................................................................................#...................#........
........................#......#..........................#.....#......#................................................................#...
................................................#..........................................#.............#..................................
......................................#..............................................................................#......................
..#.................................................................#.........#.............................................................
..........#.....#...............................................................................................#...........#...............
.................................#....................................................................#..............................#......
.....................................................#........................................#........................#....................
..........................................#..................#............#.................................................................
......................#...............................................................#..................#.........#............#...........
......#........................................................................#............................................................
...................................#...................................#..................................................#.................
...................................................#.........................................#.................#............................
...........................#...................................#.....................................................................#......
........................................#...................................................................................................
................#......................................#........................#.........#.....#...........................................
...........#......................#.....................................................................#...................................
....#....................#...................#...................#................................................#...........#...........#.
............................................................................................................................................
............................................................................................................................................
.....................................#....................................#.................................................................
.......................#..................#........#............................#................#.............#............................
...............#...............................................#......................#..............................................#......
............................................................................................................................................
.................................#...........#.....................#....................................................#...................
............................................................................................................................................
..#........#..........#...............#..................................................................#..........#......................#
............................................................#............................#..................................................
.................................................................#..........#.................................#.................#...........
.............................#......................#.......................................................................................
....#..................................................................................................................................#....
...................#...............#..................................................#....................#................................
.........................................................#......................................#...................#..............#........
.....................................................................#...................................................#..................
........................#...................................................................#..................#............................
...#.....#...............................#....................#.............................................................................
................#...............#...........................................................................................................
.....................#........................................................#.....................................................#.......
..............................................#.......#................#...............................................#...................#
.........................................................................................#...............#...................#..............
.#...........................#.......#......................................................................................................
.............................................................................................................#........................#.....
.................................#..........................................................................................................
...........#........................................................................................#.............................#.........
................#...............................................#............................#...................#..........................
...#............................................................................#...........................................................
....................................................#.......#.......#......#...........................................................#....
.........................#..................................................................................................................
....................#...............#.........................................................................................#.............
.........................................................#....................#......................#......................................
....#........................#...............#........................#...............#.....................................................
..........#......#....................................................................................................................#.....
..............................................................................................#...................#.........................
.......................................................#...................................................#.................#..............
..........................#....................#............................................................................................
........................................#......................#.........#...............#.......#......................#.........#.....#...
...............................#....................................#.......................................................................
........#...........#.............................#.........................................................................................
...#...........#...................................................................#..................#............#........................
...........................#..............................#...................................#.............................................
...................................#.............................#..........................................#...............................
..............................................#........................#........#..........................................#................
.......................................................................................#.............................#..............#.......
.........................................#..................................................................................................
.....#............#......................................#.....#............................#...............................................
............................#...............................................................................................................
.......................#.........#........................................#..............................#...............................#..
..#...........#.......................................#.........................#...........................................................
.......................................#.........................#..........................................................................
............................................................#...............................................................................
.......#......................#........................................#................................................#..............#....
..............................................................................................................#.............................
...............................................#.....................................................#......................................
......................#..................................................................#......#.................................#.......#.
..#.......#................#......#..................................#.......#.....................................#........................
................#...............................................#..................#....................#..................#................

View File

@ -1,73 +0,0 @@
use crate::common::{match_inputs, read_file, split_lines};
#[allow(dead_code)]
pub fn part_two() {}
#[allow(dead_code)]
pub fn part_one() {
let input = setup();
let mut galaxies = extract(input);
expand(&mut galaxies);
let distances = sum_dist(galaxies);
println!("The sum of all distances is: '{distances}'.");
}
fn sum_dist(galaxies: Vec<Galaxy>) -> usize {
let mut distances = 0;
for (i, a) in galaxies.iter().enumerate() {
for b in galaxies.iter().skip(i) {
if b.compare(a) {
continue;
}
distances += a.distance(b);
}
}
distances
}
fn extract(symbols: Vec<Vec<String>>) -> Vec<Galaxy> {
let mut galaxies = Vec::new();
for (y, line) in symbols.iter().enumerate() {
for (x, symbol) in line.iter().enumerate() {
if symbol.as_str() == "." {
continue;
}
galaxies.push(Galaxy { x, y });
}
}
galaxies
}
fn expand(galaxies: &mut Vec<Galaxy>) {}
struct Galaxy {
x: usize,
y: usize,
}
impl Galaxy {
fn distance(&self, other: &Galaxy) -> usize {
let dx = (other.x as isize - self.x as isize).abs();
let dy = (other.y as isize - self.y as isize).abs();
(dx + dy) as usize
}
fn compare(&self, other: &Galaxy) -> bool {
self.x == other.x && self.y == other.y
}
}
fn setup() -> Vec<Vec<String>> {
let name = "day11";
println!("Executing module '{name}' entrypoint . . . ");
let content = read_file(name);
let lines = split_lines(&content);
match_inputs(lines, &r".")
}

View File

@ -1,19 +1,14 @@
use std::time::Instant; use std::time::Instant;
mod common; mod common;
mod day09; mod day09;
mod day11;
fn main() { fn main() {
println!("Executing main entrypoint . . . "); println!("Executing main entrypoint . . . ");
let now = Instant::now(); let now = Instant::now();
// day09::part_one(); // day09::part_one();
// day09::part_two(); day09::part_two();
day11::part_one();
// day11::part_two();
let elapsed = now.elapsed(); let elapsed = now.elapsed();
println!("Execution in {:?}.", elapsed); println!("Execution in {:?}.", elapsed);