advent-of-code/rs/src/y2022/d04.rs
2022-12-04 13:50:22 +01:00

31 lines
987 B
Rust

use std::ops::RangeInclusive;
fn contains(a: &RangeInclusive<u32>, b: &RangeInclusive<u32>) -> bool {
a.start() <= b.start() && b.end() <= a.end()
}
fn overlap(a: &RangeInclusive<u32>, b: &RangeInclusive<u32>) -> bool {
a.contains(b.start()) || a.contains(b.end()) || b.contains(a.start()) || b.contains(a.end())
}
pub fn solve(input: String) {
let pairs = input
.lines()
.map(|l| {
let mut ranges = l.split(',').map(|p| {
let mut numbers = p.split('-').map(|n| n.parse::<u32>().unwrap());
numbers.next().unwrap()..=numbers.next().unwrap()
});
(ranges.next().unwrap(), ranges.next().unwrap())
})
.collect::<Vec<_>>();
let score = pairs
.iter()
.filter(|(a, b)| contains(a, b) || contains(b, a))
.count();
println!("Part 1: {score}");
let score = pairs.iter().filter(|(a, b)| overlap(a, b)).count();
println!("Part 2: {score}");
}