-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path01.rs
More file actions
59 lines (47 loc) · 1.51 KB
/
01.rs
File metadata and controls
59 lines (47 loc) · 1.51 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
use std::{collections::HashMap, iter::zip};
advent_of_code::solution!(1);
pub fn part_one(input: &str) -> Option<u32> {
let mut left: Vec<u32> = Vec::new();
let mut right: Vec<u32> = Vec::new();
let mut result: Vec<u32> = Vec::new();
for line in input.lines() {
let arr: Vec<&str> = line.trim().split_whitespace().collect();
left.push(arr[0].parse().unwrap());
right.push(arr[1].parse().unwrap());
}
left.sort();
right.sort();
for (l, r) in zip(left, right) {
result.push(l.abs_diff(r));
}
Some(result.iter().sum())
}
pub fn part_two(input: &str) -> Option<u32> {
let mut left: Vec<u32> = Vec::new();
let mut right: HashMap<u32, u32> = HashMap::new();
let mut result: Vec<u32> = Vec::new();
for line in input.lines() {
let arr: Vec<&str> = line.trim().split_whitespace().collect();
left.push(arr[0].parse().unwrap());
let count = right.entry(arr[1].parse().unwrap()).or_insert(0);
*count += 1;
}
for key in left.iter() {
result.push(key * right.get(key).copied().unwrap_or(0));
}
Some(result.iter().sum())
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_part_one() {
let result = part_one(&advent_of_code::template::read_file("examples", DAY));
assert_eq!(result, Some(11));
}
#[test]
fn test_part_two() {
let result = part_two(&advent_of_code::template::read_file("examples", DAY));
assert_eq!(result, Some(31));
}
}