summary refs log tree commit diff homepage
diff options
context:
space:
mode:
authorJune McEnroe <programble@gmail.com>2017-12-14 22:17:21 -0500
committerJune McEnroe <programble@gmail.com>2017-12-14 22:17:21 -0500
commit799c56529debf4214be4c17eda81776c0f6ec691 (patch)
treea739b4fb11dc834e0c7a6bee7f85b3c4062a4549
parentDay 9 (diff)
downloadaoc-799c56529debf4214be4c17eda81776c0f6ec691.tar.gz
aoc-799c56529debf4214be4c17eda81776c0f6ec691.zip
Day 9, part 2
-rw-r--r--2017/src/bin/day09.rs29
1 files changed, 27 insertions, 2 deletions
diff --git a/2017/src/bin/day09.rs b/2017/src/bin/day09.rs
index a8492d0..e88b6f4 100644
--- a/2017/src/bin/day09.rs
+++ b/2017/src/bin/day09.rs
@@ -1,6 +1,6 @@
 use std::io::{self, Read};
 
-#[derive(Debug, Clone, Copy)]
+#[derive(Debug, Clone, Copy, PartialEq, Eq)]
 enum State {
     Group,
     Garbage,
@@ -9,7 +9,7 @@ enum State {
 
 use self::State::*;
 
-#[derive(Debug, Clone, Copy)]
+#[derive(Debug, Clone, Copy, PartialEq, Eq)]
 struct Machine(State, u32);
 
 impl Machine {
@@ -41,11 +41,25 @@ fn solve1(input: &str) -> u32 {
     score
 }
 
+fn solve2(input: &str) -> u32 {
+    let mut garbage = 0;
+    let mut state = Machine(Group, 0);
+    for c in input.chars() {
+        let next = state.next(c);
+        if next == state && state.0 == Garbage {
+            garbage += 1;
+        }
+        state = next;
+    }
+    garbage
+}
+
 fn main() {
     let mut input = String::new();
     io::stdin().read_to_string(&mut input).unwrap();
 
     println!("Part 1: {}", solve1(input.trim()));
+    println!("Part 2: {}", solve2(input.trim()));
 }
 
 #[test]
@@ -59,3 +73,14 @@ fn part1() {
     assert_eq!(9, solve1("{{<!!>},{<!!>},{<!!>},{<!!>}}"));
     assert_eq!(3, solve1("{{<a!>},{<a!>},{<a!>},{<ab>}}"));
 }
+
+#[test]
+fn part2() {
+    assert_eq!(0, solve2("<>"));
+    assert_eq!(17, solve2("<random characters>"));
+    assert_eq!(3, solve2("<<<<>"));
+    assert_eq!(2, solve2("<{!>}>"));
+    assert_eq!(0, solve2("<!!>"));
+    assert_eq!(0, solve2("<!!!>>"));
+    assert_eq!(10, solve2("<{o\"i!a,<{i<a>"));
+}
d>Update Terminal.app coloursJune McEnroe God what is this garbage I only changed one colour. 2021-01-13Increase dark white brightness slightlyJune McEnroe 2021-01-13Add hilex example to htagml manualJune McEnroe 2021-01-12Style causal.agency like bin HTMLJune McEnroe 2021-01-12Avoid matching tag text inside HTML elementsJune McEnroe 2021-01-12Use hilex for up -hJune McEnroe 2021-01-12Use hilex for bin HTMLJune McEnroe 2021-01-12Don't output a pre in hilex by defaultJune McEnroe 2021-01-12Move hilex out of hilex directoryJune McEnroe 2021-01-12Consolidate hilex formatters into hilex.cJune McEnroe 2021-01-12Remove hacky tagging from hilexJune McEnroe God that makes the lexers so much simpler. 2021-01-12Add htagml -iJune McEnroe 2021-01-12Render tag index in HTMLJune McEnroe 2021-01-12Add htagml -xJune McEnroe 2021-01-12Prevent matching the same tag twiceJune McEnroe 2021-01-12Process htagml file line by lineJune McEnroe This simplifies some things, adds support for line number tag definitions, and should enable combining htagml with other preprocessors in the future. 2021-01-12Split fields by tab onlyJune McEnroe Also don't fail hard on non-forward-search definitions. 2021-01-12List both Makefile and html.sh under README.7June McEnroe 2021-01-12Add htagml exampleJune McEnroe 2021-01-12Use mandoc and htagml for bin htmlJune McEnroe 2021-01-12Add htagmlJune McEnroe 2021-01-12Replace causal.agency with a simple mdoc pageJune McEnroe 2021-01-11Publish "Using vi"June McEnroe 2021-01-11Enable diff.colorMovedJune McEnroe 2021-01-10Set less search case-insensitiveJune McEnroe 2021-01-10Set EXINITJune McEnroe neovim is laggy as hell in my OpenBSD VM, so I switched to vi so I could type without getting frustrated. 2021-01-09Add c -t flag to print expression typeJune McEnroe Also add missing float case. 2021-01-05Update taglineJune McEnroe