summary refs log tree commit diff homepage
path: root/2017/src/bin/day01.rs
blob: 70ca5a61c967a9985fb7b9133292323cf331345f (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
39
40
41
42
43
44
45
use std::io::{self, Read};

fn solve(input: &str, skip: usize) -> u32 {
    let mut sum = 0;

    let chars = input.chars();
    let nexts = input.chars().cycle().skip(skip);

    for (a, b) in chars.zip(nexts) {
        if a == b {
            sum += a.to_digit(10).unwrap();
        }
    }

    sum
}

fn solve2(input: &str) -> u32 {
    solve(input, input.len() / 2)
}

fn main() {
    let mut input = String::new();
    io::stdin().read_to_string(&mut input).unwrap();

    println!("Part 1: {}", solve(input.trim(), 1));
    println!("Part 2: {}", solve2(input.trim()));
}

#[test]
fn part1() {
    assert_eq!(3, solve("1122", 1));
    assert_eq!(4, solve("1111", 1));
    assert_eq!(0, solve("1234", 1));
    assert_eq!(9, solve("91212129", 1));
}

#[test]
fn part2() {
    assert_eq!(6, solve2("1212"));
    assert_eq!(0, solve2("1221"));
    assert_eq!(4, solve2("123425"));
    assert_eq!(12, solve2("123123"));
    assert_eq!(4, solve2("12131415"));
}
logheader'>2019-07-27Update macOS neovim to 0.3.8June McEnroe Which somehow still doesn't include my man fix. 2019-07-27Rewrite port makefiles consistentlyJune McEnroe 2019-07-27Rewrite Makefile once more with more organizationJune McEnroe 2019-07-27Reference png.h in bin.7June McEnroe 2019-07-27Revert "Use scheme to style HTMLs"June McEnroe This reverts commit 4b7d5161a30645b0a23691687ef1aafdda62d3bb. I don't know why but I don't like it. 2019-07-27Remove scheme text linkJune McEnroe No standard base64 encoder so no way to maintain it. 2019-07-26Update Dark.terminalJune McEnroe Why are the blobs so much bigger now? 2019-07-26Lighten dark whiteJune McEnroe 2019-07-25Add png.3 man pageJune McEnroe 2019-07-25Use scheme to style HTMLsJune McEnroe 2019-07-25Don't match comments in strings in makeJune McEnroe 2019-07-25Generate index.html with links from bin.7June McEnroe 2019-07-24Warn when date has changedJune McEnroe 2019-07-24Add whenJune McEnroe When? Now. 2019-07-24Remove histedit from bitJune McEnroe