day 1: part 1: rust

This commit is contained in:
Samuel Ortion 2024-12-01 10:27:50 +01:00
parent 1a8565b67c
commit d348f1ad22
Signed by: sortion
GPG Key ID: 9B02406F8C4FB765
2 changed files with 54 additions and 0 deletions

View File

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

View File

@ -0,0 +1,48 @@
fn vec_minimum(vec: &Vec<u64>) -> (usize, u64) {
let mut m: u64 = u64::MAX;
let mut index: usize = 0;
for (i, value) in vec.iter().enumerate() {
if *value < m {
m = *value;
index = i;
}
}
(index, m)
}
fn vec_distance(nums1: Vec<u64>, nums2: Vec<u64>) -> u64 {
let mut nums1 = nums1.clone();
let mut nums2 = nums2.clone();
let mut distance: u64 = 0;
while nums1.len() > 0 {
let (idx1, min1) = vec_minimum(&nums1);
let (idx2, min2) = vec_minimum(&nums2);
let d = (min1 as i64 - min2 as i64).abs() as u64;
distance += d;
nums1.remove(idx1);
nums2.remove(idx2);
}
distance
}
fn main() -> std::io::Result<()> {
let mut nums1: Vec<u64> = Vec::new();
let mut nums2: Vec<u64> = Vec::new();
for line in std::io::stdin().lines() {
let line = line.unwrap();
if line == "" {
continue;
}
let mut parts = line.split(" ");
let num1 = parts.next().unwrap();
let num1: u64 = num1.parse().unwrap();
let num2 = parts.next().unwrap();
let num2: u64 = num2.parse().unwrap();
nums1.push(num1);
nums2.push(num2);
}
let distance = vec_distance(nums1, nums2);
println!("{}", distance);
Ok(())
}