Solution for 2022/day03-part1
This commit is contained in:
parent
ffe0476ea0
commit
da73445a67
8
2022/day03-part1/Cargo.toml
Normal file
8
2022/day03-part1/Cargo.toml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
[package]
|
||||||
|
name = "day03-part1"
|
||||||
|
version = "0.1.0"
|
||||||
|
edition = "2021"
|
||||||
|
|
||||||
|
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
36
2022/day03-part1/src/main.rs
Normal file
36
2022/day03-part1/src/main.rs
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
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 mut input = input.lines();
|
||||||
|
|
||||||
|
// --- TASK BEGIN ---
|
||||||
|
let mut total = 0;
|
||||||
|
while let Some(line) = input.next() {
|
||||||
|
// Split the string into two strings, exactly in the middle.
|
||||||
|
let (left, right) = line.split_at(line.as_bytes().len() / 2);
|
||||||
|
// Turn the left and right strings into HashSets.
|
||||||
|
let left: HashSet<char> = left.chars().collect();
|
||||||
|
let right: HashSet<char> = right.chars().collect();
|
||||||
|
// Use set intersection to determine the item that's in both compartments.
|
||||||
|
let item = *left.intersection(&right).next().unwrap();
|
||||||
|
// Calculate the priority.
|
||||||
|
let priority = match item {
|
||||||
|
item if item.is_ascii_lowercase() => (item as u32) - ('a' as u32) + 1,
|
||||||
|
item if item.is_ascii_uppercase() => (item as u32) - ('A' as u32) + 27,
|
||||||
|
_ => {panic!("Character out of range")}
|
||||||
|
};
|
||||||
|
// Accumulate the priorities.
|
||||||
|
total += priority;
|
||||||
|
}
|
||||||
|
println!("Total priority: {total}");
|
||||||
|
}
|
||||||
|
|
||||||
Loading…
Reference in New Issue
Block a user