solution: day3
This commit is contained in:
parent
00000030c4
commit
00000040fe
|
@ -0,0 +1,66 @@
|
||||||
|
use std::collections::HashSet;
|
||||||
|
|
||||||
|
use itertools::Itertools;
|
||||||
|
|
||||||
|
pub fn part_one(input: &str) -> Option<u32> {
|
||||||
|
let mut visited = HashSet::with_capacity(input.len());
|
||||||
|
visited.insert((0,0));
|
||||||
|
let mut x = 0;
|
||||||
|
let mut y = 0;
|
||||||
|
for direction in input.trim().chars() {
|
||||||
|
match direction {
|
||||||
|
'>' => x += 1,
|
||||||
|
'<' => x -= 1,
|
||||||
|
'^' => y += 1,
|
||||||
|
'v' => y -= 1,
|
||||||
|
_ => panic!("oops")
|
||||||
|
};
|
||||||
|
visited.insert((x, y));
|
||||||
|
};
|
||||||
|
Some(visited.len() as u32)
|
||||||
|
}
|
||||||
|
pub fn part_two(input: &str) -> Option<u32> {
|
||||||
|
let mut visited = HashSet::with_capacity(input.len());
|
||||||
|
visited.insert((0,0));
|
||||||
|
let (mut x1, mut y1, mut x2, mut y2) = (0, 0, 0, 0);
|
||||||
|
for (santa, robot) in input.trim().chars().tuple_windows().step_by(2) {
|
||||||
|
match santa {
|
||||||
|
'>' => x1 += 1,
|
||||||
|
'<' => x1 -= 1,
|
||||||
|
'^' => y1 += 1,
|
||||||
|
'v' => y1 -= 1,
|
||||||
|
_ => panic!("oops")
|
||||||
|
};
|
||||||
|
visited.insert((x1, y1));
|
||||||
|
match robot {
|
||||||
|
'>' => x2 += 1,
|
||||||
|
'<' => x2 -= 1,
|
||||||
|
'^' => y2 += 1,
|
||||||
|
'v' => y2 -= 1,
|
||||||
|
_ => panic!("oops")
|
||||||
|
};
|
||||||
|
visited.insert((x2, y2));
|
||||||
|
};
|
||||||
|
Some(visited.len() as u32)
|
||||||
|
}
|
||||||
|
fn main() {
|
||||||
|
let input = &aoc::read_file("inputs", 3);
|
||||||
|
aoc::solve!(1, part_one, input);
|
||||||
|
aoc::solve!(2, part_two, input);
|
||||||
|
}
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
#[test]
|
||||||
|
fn test_part_one() {
|
||||||
|
// let input = aoc::read_file("test_inputs", 3);
|
||||||
|
let input = "^v^v^v^v^v";
|
||||||
|
assert_eq!(part_one(&input), Some(2));
|
||||||
|
}
|
||||||
|
#[test]
|
||||||
|
fn test_part_two() {
|
||||||
|
// let input = aoc::read_file("test_inputs", 3);
|
||||||
|
let input = "^v^v^v^v^v";
|
||||||
|
assert_eq!(part_two(&input), Some(11));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue