summary refs log tree commit diff homepage
path: root/src/bin/day19.rs
blob: 89013b327daad0a6e9f6ef6b7ba55d4a22159fe7 (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
use std::io::{self, Read};

#[derive(Clone, Copy)]
struct Elf {
    gifts: usize,
    next: usize,
}

fn solve(count: usize) -> usize {
    let mut circle: Vec<Elf> = (0..count).map(|i| Elf { gifts: 1, next: i + 1 }).collect();
    circle.last_mut().unwrap().next = 0;

    let mut index = 0;

    while circle[index].gifts < count {
        let next = circle[index].next;
        circle[index].gifts += circle[next].gifts;
        circle[next].gifts = 0;
        circle[index].next = circle[next].next;

        index = circle[index].next;
    }

    index + 1
}

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

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

#[test]
fn part1() {
    assert_eq!(3, solve(5));
}