use std::collections::HashSet; fn character_to_code(input: i32) -> i32 { if input >= ('a' as i32) { input - 96 } else { input - 38 } } pub fn solve_part1(file_path: &str) -> i32 { let binding = std::fs::read_to_string(file_path).expect("Please provide a text file as an argument."); binding .lines() .collect::>() .iter() .map(|item: &&str| { let (first, last) = item.split_at(item.len() / 2); let second = last.chars().collect::>(); let intersection = first.chars().collect::>(); let character = *intersection .intersection(&second) .next() .unwrap_or(&(0 as char)) as i32; character_to_code(character) }) .collect::>() .iter() .sum::() } pub fn solve_part2(file_path: &str) -> i32 { let binding = std::fs::read_to_string(file_path).expect("Please provide a text file as an argument."); let mut iter = binding.lines(); binding .lines() .step_by(3) .collect::>() .iter() .map(|_item| { let common_letter = { let first = &iter .next() .expect("Expected a string, not nothing.") .chars() .collect::>() & &iter .next() .expect("Expected a string, not nothing.") .chars() .collect::>(); &first & &iter .next() .expect("Expected a string, not nothing.") .chars() .collect::>() }; if !common_letter.is_empty() && common_letter.len() > 1 { panic!("Anormal behavior. Must have only 1 element in {common_letter:?}"); } else { let unique_letter = *common_letter .iter() .last() .expect("Impossible to have this message else Rust has a problem...") as i32; character_to_code(unique_letter) } }) .collect::>() .iter() .sum::() }