feat: added day 7 part 1 and 2
All checks were successful
Build and run challenges / Challenge for day (1) (push) Successful in 3s
Build and run challenges / Challenge for day (2) (push) Successful in 3s
Build and run challenges / Challenge for day (5) (push) Successful in 5s
Build and run challenges / Challenge for day (3) (push) Successful in 11s
Build and run challenges / Challenge for day (6) (push) Successful in 5s
Build and run challenges / Challenge for day (7) (push) Successful in 4s
Build and run challenges / Challenge for day (4) (push) Successful in 4s

Signed-off-by: Louis Vallat <contact@louis-vallat.dev>
This commit is contained in:
Louis Vallat 2024-12-08 15:11:21 +01:00
parent 57e93cffdc
commit 005bdb82af
Signed by: louis
SSH Key Fingerprint: SHA256:0iPwDU/PZtEy/K13Oar4TzmcunmI9H5U9IsOR3jyT/Q
3 changed files with 112 additions and 1 deletions

View File

@ -11,7 +11,7 @@ jobs:
name: Challenge for day name: Challenge for day
strategy: strategy:
matrix: matrix:
day_number: [1, 2, 3, 4, 5, 6] day_number: [1, 2, 3, 4, 5, 6, 7]
runs-on: rust-bookworm runs-on: rust-bookworm
steps: steps:
- name: Check out repository code - name: Check out repository code

6
day7/Cargo.toml Normal file
View File

@ -0,0 +1,6 @@
[package]
name = "day7"
version = "0.1.0"
edition = "2021"
[dependencies]

105
day7/src/main.rs Normal file
View File

@ -0,0 +1,105 @@
use std::{env, fs};
fn read_input(path: &str) -> String {
fs::read_to_string(path).expect("Cannot read file.")
}
fn add(a: u64, b: u64) -> u64 {
a + b
}
fn mul(a: u64, b: u64) -> u64 {
a * b
}
fn concat(a: u64, b: u64) -> u64 {
format!("{a}{b}").parse().unwrap()
}
fn parse_input(input: &str) -> Vec<(u64, Vec<u64>)> {
input
.lines()
.filter(|line| !line.is_empty())
.map(|line| {
let split_line = line.split_once(": ").unwrap();
(
split_line.0.parse().unwrap(),
split_line
.1
.split_whitespace()
.map(|s| s.parse().unwrap())
.rev()
.collect(),
)
})
.collect()
}
fn is_valid(
data: &mut Vec<u64>,
acc: u64,
target: u64,
operators: &Vec<&fn(u64, u64) -> u64>,
) -> bool {
if data.is_empty() {
return target == acc;
}
if acc > target {
return false;
}
let old = data.pop().unwrap();
for operator in operators {
if is_valid(data, operator(acc, old), target, operators) {
return true;
}
}
data.push(old);
false
}
fn sum_valid(
calibration_data: &Vec<(u64, Vec<u64>)>,
operators: &Vec<&fn(u64, u64) -> u64>,
) -> u64 {
let mut sum_valid = 0;
let calibration_data = calibration_data.clone();
for calibration in calibration_data {
let mut x = calibration.1;
let acc = x.pop().unwrap();
if is_valid(&mut x, acc, calibration.0, operators) {
sum_valid += calibration.0;
}
}
sum_valid
}
fn part_1(input: &Vec<(u64, Vec<u64>)>) -> u64 {
let valid_operators = vec![&(add as fn(u64, u64) -> u64), &(mul as fn(u64, u64) -> u64)];
sum_valid(input, &valid_operators)
}
fn part_2(input: &Vec<(u64, Vec<u64>)>) -> u64 {
let valid_operators = vec![
&(add as fn(u64, u64) -> u64),
&(mul as fn(u64, u64) -> u64),
&(concat as fn(u64, u64) -> u64),
];
sum_valid(input, &valid_operators)
}
fn main() {
let args: Vec<String> = env::args().collect();
for arg in args.iter().skip(1) {
let input = read_input(&arg);
let calibration_data = parse_input(&input);
println!("[{}]", &arg);
println!("\t[Part 1] => Answer is '{}'.", part_1(&calibration_data));
println!("\t[Part 2] => Answer is '{}'.", part_2(&calibration_data));
}
}