Day 4!
This commit is contained in:
parent
501706b863
commit
846cfe0da6
3 changed files with 1086 additions and 0 deletions
1000
2022/Data/day4-input.txt
Normal file
1000
2022/Data/day4-input.txt
Normal file
File diff suppressed because it is too large
Load diff
80
2022/aoc2022/src/day4.rs
Normal file
80
2022/aoc2022/src/day4.rs
Normal file
|
@ -0,0 +1,80 @@
|
||||||
|
use std::io::Result;
|
||||||
|
use std::ops::RangeInclusive;
|
||||||
|
|
||||||
|
use crate::file::line_reader_for_file;
|
||||||
|
|
||||||
|
#[derive(PartialEq, PartialOrd)]
|
||||||
|
struct RangeString(String);
|
||||||
|
|
||||||
|
impl From<&str> for RangeString {
|
||||||
|
fn from(s: &str) -> Self { RangeString(s.to_string()) }
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<RangeString> for RangeInclusive<u32> {
|
||||||
|
fn from(s: RangeString) -> Self {
|
||||||
|
let mut bounds = s.0.split("-");
|
||||||
|
let start = u32::from_str_radix(bounds.next().unwrap(), 10).unwrap();
|
||||||
|
let end = u32::from_str_radix(bounds.next().unwrap(), 10).unwrap();
|
||||||
|
assert!(bounds.next() == None);
|
||||||
|
start..=end
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct Assignment {
|
||||||
|
left: RangeInclusive<u32>,
|
||||||
|
right: RangeInclusive<u32>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Assignment {
|
||||||
|
fn from_left_and_right_specifier(
|
||||||
|
left_specifier: RangeString,
|
||||||
|
right_specifier: RangeString) -> Assignment
|
||||||
|
{
|
||||||
|
Assignment {
|
||||||
|
left: RangeInclusive::<u32>::from(left_specifier),
|
||||||
|
right: RangeInclusive::<u32>::from(right_specifier),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn has_range_contained_by_other(&self) -> bool {
|
||||||
|
let left_contains_right = self.left.contains(self.right.start())
|
||||||
|
&& self.left.contains(self.right.end());
|
||||||
|
let right_contains_left = self.right.contains(self.left.start())
|
||||||
|
&& self.right.contains(self.left.end());
|
||||||
|
|
||||||
|
left_contains_right || right_contains_left
|
||||||
|
}
|
||||||
|
|
||||||
|
fn has_overlapping_range(&self) -> bool {
|
||||||
|
self.left.contains(self.right.start())
|
||||||
|
|| self.left.contains(self.right.end())
|
||||||
|
|| self.right.contains(self.left.start())
|
||||||
|
|| self.right.contains(self.left.end())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn main(filename: &str) -> Result<()> {
|
||||||
|
let assignment_counts: (u32, u32, u32) = line_reader_for_file(filename)?
|
||||||
|
.map(|line| -> Assignment {
|
||||||
|
let line = line.unwrap();
|
||||||
|
let mut elves = line.split(",").map(|s| RangeString::from(s));
|
||||||
|
let assignment = Assignment::from_left_and_right_specifier(
|
||||||
|
elves.next().unwrap(),
|
||||||
|
elves.next().unwrap());
|
||||||
|
|
||||||
|
assert!(elves.next() == None);
|
||||||
|
|
||||||
|
assignment
|
||||||
|
})
|
||||||
|
.fold((0, 0, 0), |acc, a| {
|
||||||
|
let part1_counter = acc.1 + if a.has_range_contained_by_other() { 1 } else { 0 };
|
||||||
|
let part2_counter = acc.2 + if a.has_overlapping_range() { 1 } else { 0 };
|
||||||
|
(acc.0 + 1, part1_counter, part2_counter)
|
||||||
|
});
|
||||||
|
|
||||||
|
println!("Processed {} assignments", assignment_counts.0);
|
||||||
|
println!("Part 1: number of assignments with one range containing the other: {}", assignment_counts.1);
|
||||||
|
println!("Part 2: number of assignments with ranges at least partially overlapping: {}", assignment_counts.2);
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
|
@ -3,6 +3,7 @@ use std::env;
|
||||||
mod day1;
|
mod day1;
|
||||||
mod day2;
|
mod day2;
|
||||||
mod day3;
|
mod day3;
|
||||||
|
mod day4;
|
||||||
mod file;
|
mod file;
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
@ -24,4 +25,9 @@ fn main() {
|
||||||
let day3_datafile = &args[3];
|
let day3_datafile = &args[3];
|
||||||
day3::main(day3_datafile.as_str())
|
day3::main(day3_datafile.as_str())
|
||||||
.expect("Unable to process day3 data file");
|
.expect("Unable to process day3 data file");
|
||||||
|
|
||||||
|
println!("----- Day 4 -----");
|
||||||
|
let day4_datafile = &args[4];
|
||||||
|
day4::main(day4_datafile.as_str())
|
||||||
|
.expect("Unable to process day4 data file");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue