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

Signed-off-by: Louis Vallat <contact@louis-vallat.fr>
This commit is contained in:
Louis Vallat 2024-12-02 00:28:12 +01:00
commit fee30a713d
Signed by: louis
SSH Key Fingerprint: SHA256:0iPwDU/PZtEy/K13Oar4TzmcunmI9H5U9IsOR3jyT/Q
5 changed files with 1095 additions and 0 deletions

View File

@ -0,0 +1,22 @@
name: Build and run challenges
defaults:
run:
shell: sh
on:
push:
jobs:
build-and-run:
name: Challenge for day
strategy:
matrix:
day_number: [1]
runs-on: rust-bookworm
steps:
- name: Check out repository code
uses: actions/checkout@v4
- name: Run challenge
run: |
cd day${{ matrix.day_number }}
cargo run --release ./input

3
.gitignore vendored Normal file
View File

@ -0,0 +1,3 @@
target
Cargo.lock
.idea/

6
day1/Cargo.toml Normal file
View File

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

1000
day1/input Normal file

File diff suppressed because it is too large Load Diff

64
day1/src/main.rs Normal file
View File

@ -0,0 +1,64 @@
use std::collections::HashMap;
use std::{env, fs};
fn read_input(path: &str) -> String {
fs::read_to_string(path).expect("Cannot read file.")
}
fn parse_input(input: &str) -> (Vec<i32>, Vec<i32>) {
input
.lines()
.filter(|line| !line.is_empty())
.fold((vec![], vec![]), |mut acc, line| {
let split = line.trim().split_once(" ").expect("Cannot split line.");
acc.0.push(
split
.0
.parse::<i32>()
.expect("Cannot parse integer on the left."),
);
acc.1.push(
split
.1
.parse::<i32>()
.expect("Cannot parse integer on the right."),
);
acc
})
}
fn part_1(left: &Vec<i32>, right: &Vec<i32>) -> i32 {
let mut left = left.clone();
let mut right = right.clone();
left.sort();
right.sort();
let mut sum = 0;
for (i, x) in left.iter().enumerate() {
sum += (x - right[i]).abs();
}
sum
}
fn part_2(left: &Vec<i32>, right: &Vec<i32>) -> i32 {
let mut occur = HashMap::new();
for x in right.iter() {
*occur.entry(x).or_insert(0) += 1;
}
let mut sum = 0;
for x in left.iter() {
sum += x * occur.get(x).unwrap_or(&0);
}
sum
}
fn main() {
let args: Vec<String> = env::args().collect();
for arg in args.iter().skip(1) {
let input = read_input(&arg);
let (left, right) = parse_input(&input);
println!("[{}]", &arg);
println!("\t[Part 1] => Answer is '{}'.", part_1(&left, &right));
println!("\t[Part 2] => Answer is '{}'.", part_2(&left, &right));
}
}