This commit is contained in:
Fabian Schmidt 2024-12-02 10:47:39 +01:00
parent a1183f8ef4
commit 67d3a56011
4 changed files with 1136 additions and 0 deletions

1000
y2024/resources/2_input.txt Normal file

File diff suppressed because it is too large Load Diff

20
y2024/src/bin/d2.rs Normal file
View File

@ -0,0 +1,20 @@
use std::fs;
use y2024::days::d2;
fn main() {
part1();
part2();
}
fn part1() {
let root = env!("CARGO_MANIFEST_DIR");
let content = fs::read_to_string(format!("{root}/resources/2_input.txt")).unwrap();
println!("{}", d2::process_part1(&content));
}
fn part2() {
let root = env!("CARGO_MANIFEST_DIR");
let content = fs::read_to_string(format!("{root}/resources/2_input.txt")).unwrap();
println!("{}", d2::process_part2(&content));
}

115
y2024/src/days/d2.rs Normal file
View File

@ -0,0 +1,115 @@
#[derive(Clone, Copy, Debug)]
enum Order {
Increasing,
Decreasing,
}
pub fn process_part1(input: &str) -> i32 {
let mut safe = 0;
input.lines().for_each(|line| {
let levels = line
.split_whitespace()
.map(|e| e.parse::<i32>().unwrap())
.collect::<Vec<i32>>();
if is_safe(levels) {
safe += 1;
}
});
safe
}
pub fn process_part2(input: &str) -> i32 {
let mut safe = 0;
input.lines().for_each(|line| {
let levels = line
.split_whitespace()
.map(|e| e.parse::<i32>().unwrap())
.collect::<Vec<i32>>();
if is_safe(levels.clone()) {
safe += 1;
} else {
for idx in 0..levels.len() {
let mut new_levels = levels.clone();
new_levels.remove(idx);
if is_safe(new_levels) {
safe += 1;
break;
}
}
}
});
safe
}
fn is_safe(levels: Vec<i32>) -> bool {
let mut order = None;
let mut is_safe = true;
for level_pair in levels.windows(2) {
let difference = level_pair[0] - level_pair[1];
let new_order = match difference.cmp(&0) {
std::cmp::Ordering::Less => Some(Order::Increasing),
std::cmp::Ordering::Equal => None,
std::cmp::Ordering::Greater => Some(Order::Decreasing),
};
let difference = difference.abs();
if difference == 0 {
is_safe = false;
break;
}
match (order, new_order) {
(None, Some(new_order)) => {
if difference <= 3 {
order = Some(new_order);
} else {
is_safe = false;
break;
}
}
(Some(Order::Increasing), Some(Order::Decreasing))
| (Some(Order::Decreasing), Some(Order::Increasing)) => {
is_safe = false;
break;
}
(None, None)
| (Some(_), None)
| (Some(Order::Increasing), Some(Order::Increasing))
| (Some(Order::Decreasing), Some(Order::Decreasing)) => {
if difference > 3 {
is_safe = false;
break;
}
}
};
}
if is_safe {
true
//println!("line {line} is safe");
} else {
false
//println!("line {line} is unsafe");
}
}
#[cfg(test)]
mod tests {
use super::*;
const INPUT: &str = "7 6 4 2 1
1 2 7 8 9
9 7 6 2 1
1 3 2 4 5
8 6 4 4 1
1 3 6 7 9";
#[test]
fn part1() {
let result = process_part1(INPUT);
assert_eq!(result, 2);
}
#[test]
fn part2() {
let result = process_part2(INPUT);
assert_eq!(result, 4);
}
}

View File

@ -1,2 +1,3 @@
pub mod d1; pub mod d1;
pub mod d2;