Solution for 2022/day04-part1

This commit is contained in:
Tobias Marschner 2024-02-11 06:03:40 +01:00
parent 4ba0770fe6
commit d865aaf950
2 changed files with 46 additions and 0 deletions

View File

@ -0,0 +1,8 @@
[package]
name = "day04-part1"
version = "0.1.0"
edition = "2021"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]

View File

@ -0,0 +1,38 @@
use std::collections::HashSet;
fn main() {
// Use command line arguments to specify the input filename.
let args: Vec<String> = std::env::args().collect();
if args.len() < 2 {
panic!("Usage: ./main <input-file>\nNo input file provided. Exiting.");
}
// Next, read the contents of the input file into a string for easier processing.
let input = std::fs::read_to_string(&args[1]).expect("Error opening file");
// Line-by-line processing is easiest.
let input = input.lines();
// --- TASK BEGIN ---
let mut count = 0;
for line in input {
// Turn "1-2,3-6" into ["1-2", "3-6"].
let ranges = line.split(',').collect::<Vec<_>>();
// Turn ["1-2", "3-6"] into [["1", "2"], ["3", "6"]]
let ranges = ranges.iter().map(|x| x.split('-').collect::<Vec<_>>()).collect::<Vec<_>>();
// Turn [["1", "2"], ["3", "6"]] into [1..=2, 3..=6]
let ranges = ranges.iter().map(|x| (x[0].parse::<i32>().unwrap())..=(x[1].parse::<i32>().unwrap())).collect::<Vec<_>>();
// Now turn the ranges into HashSets containing the respective integers. Essentially:
// Turn [1..=2, 3..=6] into [{1,2}, {3,4,5,6}]
let sets = ranges.into_iter().map(|x| x.collect::<HashSet<_>>()).collect::<Vec<_>>();
if sets[0].is_subset(&sets[1]) || sets[1].is_subset(&sets[0]) {
count += 1;
}
}
println!("Count: {}", count);
}