summary refs log tree commit diff homepage
path: root/src/bin
diff options
context:
space:
mode:
authorJune McEnroe <programble@gmail.com>2016-12-20 20:16:07 -0500
committerJune McEnroe <programble@gmail.com>2016-12-20 20:16:07 -0500
commit4d8d30e54d2b0b3181863b825f9c7813676acc0a (patch)
treeac012698243403f5e02f2481708d4a0b67761a11 /src/bin
parentFuck day 11 part 2 (diff)
downloadaoc-4d8d30e54d2b0b3181863b825f9c7813676acc0a.tar.gz
aoc-4d8d30e54d2b0b3181863b825f9c7813676acc0a.zip
Day 19
Diffstat (limited to 'src/bin')
-rw-r--r--src/bin/day19.rs37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/bin/day19.rs b/src/bin/day19.rs
new file mode 100644
index 0000000..89013b3
--- /dev/null
+++ b/src/bin/day19.rs
@@ -0,0 +1,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));
+}
dow coloursJune McEnroe 2021-02-07Add -X flag to install X stuff on OpenBSDJune McEnroe 2021-02-07Adjust brightness by smaller incrementsJune McEnroe 2021-02-07Fix cwm window cycling, move big by defaultJune McEnroe 2021-02-07Use class names for Foreground, Background, BorderColorJune McEnroe 2021-02-07Add simple battery status and clock to xsessionJune McEnroe 2021-02-07Set cursor theme and sizeJune McEnroe 2021-02-07Use scrot for up -s if no screencaptureJune McEnroe 2021-02-07Enable mouse acceleration in XJune McEnroe 2021-02-07Set colours for Xt and cwmJune McEnroe 2021-02-07Set urgency on bell in xtermJune McEnroe 2021-02-07Add bindings for brightness controlJune McEnroe 2021-02-07Set X key repeat rateJune McEnroe 2021-02-07Bump font size to 12June McEnroe 2021-02-07Fully configure and rebind cwmJune McEnroe 2021-02-07Add BintiJune McEnroe 2021-02-07Finish configuring xtermJune McEnroe 2021-02-06Enable tapping, reverse scroll, set scaling in wsconsctlJune McEnroe 2021-02-06Set root window to black on purple snowJune McEnroe 2021-02-06Add xmodmap configurationJune McEnroe 2021-02-06Add initial OpenBSD X configurationJune McEnroe 2021-02-06Add xterm output to schemeJune McEnroe