summaryrefslogtreecommitdiffstats
path: root/src/bin/2022/day6.rs
blob: 6fe154f3399946aa146d1af8a12efd5e387af155 (plain) (blame)
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
#![allow(dead_code)]
#![allow(unused_variables)]

use advent_of_code::prelude::*;

pub fn parse(fh: File) -> Result<String> {
    Ok(parse::string(fh))
}

pub fn part1(s: String) -> Result<usize> {
    for (i, slice) in s.as_bytes().windows(4).enumerate() {
        if slice.iter().copied().collect::<HashSet<u8>>().len() == 4 {
            return Ok(i + 4);
        }
    }
    Err(anyhow!("couldn't find marker"))
}

pub fn part2(s: String) -> Result<usize> {
    for (i, slice) in s.as_bytes().windows(14).enumerate() {
        if slice.iter().copied().collect::<HashSet<u8>>().len() == 14 {
            return Ok(i + 14);
        }
    }
    Err(anyhow!("couldn't find marker"))
}

#[test]
fn test() {
    assert_eq!(
        part1(parse(parse::data(2022, 6).unwrap()).unwrap()).unwrap(),
        1155
    );
    assert_eq!(
        part2(parse(parse::data(2022, 6).unwrap()).unwrap()).unwrap(),
        2789
    );
}