day5: add RangeSet based impl

This commit is contained in:
2025-12-05 18:02:44 -08:00
parent 324923b284
commit 57932373d6

View File

@@ -87,7 +87,7 @@ impl RangeSet {
} }
} }
#[aoc_generator(day5, part1)] #[aoc_generator(day5)]
fn parse(input: &str) -> Database { fn parse(input: &str) -> Database {
let mut fresh_ingredients = Vec::new(); let mut fresh_ingredients = Vec::new();
let mut available_ingredients = Vec::new(); let mut available_ingredients = Vec::new();
@@ -122,7 +122,7 @@ fn part1(input: &Database) -> u64 {
.count() as u64 .count() as u64
} }
#[aoc_generator(day5, part2)] #[aoc_generator(day5, part2, Naive)]
fn parse2(input: &str) -> Database2 { fn parse2(input: &str) -> Database2 {
let mut fresh_ingredients = Vec::new(); let mut fresh_ingredients = Vec::new();
for line in input.lines() { for line in input.lines() {
@@ -135,7 +135,7 @@ fn parse2(input: &str) -> Database2 {
Database2 { fresh_ingredients } Database2 { fresh_ingredients }
} }
#[aoc(day5, part2)] #[aoc(day5, part2, Naive)]
fn part2(input: &Database2) -> u64 { fn part2(input: &Database2) -> u64 {
let mut all_ingredients = RangeSet::new(); let mut all_ingredients = RangeSet::new();
for r in &input.fresh_ingredients { for r in &input.fresh_ingredients {
@@ -145,6 +145,15 @@ fn part2(input: &Database2) -> u64 {
all_ingredients.ranges.iter().map(|r| r.len()).sum::<u64>() all_ingredients.ranges.iter().map(|r| r.len()).sum::<u64>()
} }
#[aoc(day5, part2, RangeSet)]
fn part2_rangeset(input: &Database) -> u64 {
let mut all_ingredients = misc::range::RangeSet::new();
for r in &input.fresh_ingredients {
all_ingredients.add(r);
}
all_ingredients.store.iter().map(|r| r.end - r.start).sum()
}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use super::*; use super::*;
@@ -170,4 +179,9 @@ mod tests {
fn part2_example() { fn part2_example() {
assert_eq!(part2(&parse2(EXAMPLE)), 14); assert_eq!(part2(&parse2(EXAMPLE)), 14);
} }
#[test]
fn part2_set_example() {
assert_eq!(part2_rangeset(&parse(EXAMPLE)), 14);
}
} }