diff options
author | June McEnroe <programble@gmail.com> | 2017-12-23 19:42:36 -0500 |
---|---|---|
committer | June McEnroe <programble@gmail.com> | 2017-12-23 19:42:36 -0500 |
commit | 038a1c993c3160eccfe231f5e622f94e999799d9 (patch) | |
tree | e79bcacbfd59c8059a66886ed04d6cd744ccbf1d /2017/src/bin | |
parent | Day 13, part 2 (diff) | |
download | aoc-038a1c993c3160eccfe231f5e622f94e999799d9.tar.gz aoc-038a1c993c3160eccfe231f5e622f94e999799d9.zip |
Day 14
Diffstat (limited to '')
-rw-r--r-- | 2017/src/bin/day14.rs | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/2017/src/bin/day14.rs b/2017/src/bin/day14.rs new file mode 100644 index 0000000..400a29a --- /dev/null +++ b/2017/src/bin/day14.rs @@ -0,0 +1,53 @@ +use std::io::{self, Read}; + +fn reverse(ring: &mut Vec<u32>, index: usize, len: usize) { + for i in 0..(len / 2) { + let a = (index + i) % ring.len(); + let b = (index + len - 1 - i) % ring.len(); + let x = ring[a]; + ring[a] = ring[b]; + ring[b] = x; + } +} + +fn hash(input: &str) -> Vec<u8> { + let mut ring: Vec<_> = (0..256).collect(); + let mut index = 0; + let mut skip = 0; + + let mut lens: Vec<_> = input.as_bytes().to_vec(); + lens.extend(&[17, 31, 73, 47, 23]); + + for _ in 0..64 { + for len in lens.iter().cloned() { + reverse(&mut ring, index, len as usize); + index += len as usize + skip; + index %= ring.len(); + skip += 1; + } + } + + ring.chunks(16) + .map(|chunk| chunk.iter().fold(0, |a, b| a ^ b)) + .map(|x| x as u8) + .collect() +} + +fn solve1(input: &str) -> u32 { + (0..128) + .map(|i| hash(&format!("{}-{}", input, i))) + .map(|h| h.into_iter().map(u8::count_ones).sum::<u32>()) + .sum() +} + +fn main() { + let mut input = String::new(); + io::stdin().read_to_string(&mut input).unwrap(); + + println!("Part 1: {}", solve1(input.trim())); +} + +#[test] +fn part1() { + assert_eq!(8108, solve1("flqrgnkx")); +} |