From a80aa90a8b47a3e6be04a4ee1ebb11b3dd29494f Mon Sep 17 00:00:00 2001 From: Nat Lasseter Date: Sat, 8 Dec 2018 17:36:38 +0000 Subject: [day08] done --- day08/Dockerfile | 7 +++++++ day08/Makefile | 17 +++++++++++++++++ day08/entrypoint | 13 +++++++++++++ day08/input | 1 + day08/part1 | 28 ++++++++++++++++++++++++++++ day08/part2 | 36 ++++++++++++++++++++++++++++++++++++ 6 files changed, 102 insertions(+) create mode 100644 day08/Dockerfile create mode 100644 day08/Makefile create mode 100755 day08/entrypoint create mode 100644 day08/input create mode 100755 day08/part1 create mode 100755 day08/part2 diff --git a/day08/Dockerfile b/day08/Dockerfile new file mode 100644 index 0000000..5e0a8b7 --- /dev/null +++ b/day08/Dockerfile @@ -0,0 +1,7 @@ +FROM ruby:2.5-slim + +WORKDIR /opt + +COPY . . + +ENTRYPOINT ["./entrypoint"] diff --git a/day08/Makefile b/day08/Makefile new file mode 100644 index 0000000..b6cf05e --- /dev/null +++ b/day08/Makefile @@ -0,0 +1,17 @@ +DAY = 08 + +.PHONY: run clean push + +run: build + docker run -it --rm aoc2018day$(DAY) + +build: part* input + docker build -t aoc2018day$(DAY) . + touch build + +clean: + rm -f build + +push: build + docker tag aoc2018day$(DAY) advent.4574.co.uk/aoc2018day$(DAY) + docker push advent.4574.co.uk/aoc2018day$(DAY) diff --git a/day08/entrypoint b/day08/entrypoint new file mode 100755 index 0000000..8982d21 --- /dev/null +++ b/day08/entrypoint @@ -0,0 +1,13 @@ +#!/bin/bash + +if [ -x part1 ] ; then + echo -ne "Part 1:\n\t" + time ./part1 < input +fi +if [ -x part1 -a -x part2 ] ; then + echo +fi +if [ -x part2 ] ; then + echo -ne "Part 2:\n\t" + time ./part2 < input +fi diff --git a/day08/input b/day08/input new file mode 100644 index 0000000..1c689fb --- /dev/null +++ b/day08/input @@ -0,0 +1 @@ +7 11 7 3 5 5 3 5 1 8 0 11 1 6 1 1 6 4 9 4 9 7 2 2 3 1 2 2 1 2 3 1 5 0 8 1 4 1 3 6 1 7 9 1 1 2 1 3 1 5 0 10 8 5 2 9 1 8 7 1 2 7 2 1 2 3 3 4 2 4 3 4 3 4 1 6 0 7 7 1 7 1 9 8 1 2 3 3 1 3 1 1 6 0 7 1 3 9 3 6 6 8 1 2 3 2 1 2 1 9 0 8 7 1 2 1 1 8 6 9 1 2 1 2 3 2 3 2 1 5 5 3 2 3 5 1 7 0 6 6 2 4 1 7 8 2 2 1 1 1 1 1 1 6 0 7 2 7 9 1 2 8 7 2 1 3 2 1 1 1 5 0 9 1 4 6 7 4 2 7 3 9 2 3 1 3 3 4 2 3 3 2 3 7 1 5 0 8 2 4 6 1 4 7 6 2 2 1 1 1 1 1 7 0 10 7 3 2 2 3 2 6 1 2 7 1 2 2 3 2 3 1 1 8 0 7 9 3 5 4 4 1 4 1 1 1 1 3 1 2 2 1 5 2 3 2 5 1 3 4 1 8 0 8 6 1 7 5 1 3 9 9 1 1 1 2 2 2 2 2 1 7 0 7 6 4 8 6 1 5 3 1 2 3 3 1 2 1 1 5 0 7 1 8 1 5 7 7 4 1 1 3 3 2 1 1 2 1 1 3 4 3 2 5 4 3 7 1 6 0 9 7 2 1 4 9 1 6 8 3 1 3 3 2 1 2 1 7 0 8 9 1 2 1 1 7 1 1 3 1 1 2 2 3 3 1 5 0 9 1 4 5 2 3 8 3 4 7 3 1 2 3 3 1 5 5 1 1 4 3 3 5 1 5 0 9 7 6 5 1 5 1 7 3 4 3 2 2 2 1 1 5 0 10 8 5 5 7 2 5 1 9 8 5 3 3 1 1 1 1 9 0 9 9 5 7 1 5 7 3 9 7 3 3 2 3 1 2 1 1 3 2 2 1 5 1 3 6 1 6 0 6 9 8 1 3 9 3 2 2 3 1 1 3 1 7 0 11 1 1 3 3 2 3 3 1 7 7 1 2 1 3 1 2 3 2 1 9 0 6 8 6 9 9 5 1 1 2 1 1 2 3 2 3 1 5 1 4 3 1 3 3 5 1 8 0 6 7 2 6 1 5 6 2 3 1 2 1 2 1 1 1 7 0 6 6 4 2 8 1 5 2 1 1 3 1 1 2 1 6 0 11 5 6 1 2 3 1 8 6 8 9 8 3 1 1 1 2 1 1 4 3 1 3 3 6 1 8 0 6 1 2 5 2 4 9 1 2 1 1 3 2 3 2 1 5 0 9 9 5 1 6 4 1 1 3 3 1 1 2 1 1 1 9 0 11 9 2 1 9 1 1 9 4 7 6 9 1 1 1 2 3 1 1 1 1 2 5 1 4 3 5 2 7 5 1 4 5 3 4 1 5 0 9 7 9 1 5 8 3 2 3 4 2 2 2 2 1 1 6 0 10 2 7 8 5 1 2 1 9 1 9 1 1 1 2 3 1 1 5 0 8 1 1 2 8 7 8 6 2 3 1 2 2 2 2 3 3 2 3 7 1 7 0 9 5 9 2 6 7 6 1 5 1 2 1 2 2 3 2 3 1 6 0 11 6 3 6 5 3 1 9 6 5 1 4 2 3 3 1 2 3 1 8 0 7 3 7 1 6 4 1 4 2 1 1 3 1 1 3 1 4 3 2 5 1 5 2 3 6 1 7 0 11 7 3 4 1 7 9 8 7 1 9 4 3 1 3 2 1 2 1 1 6 0 7 1 3 6 9 1 8 7 1 3 3 1 3 1 1 8 0 7 1 2 1 1 4 6 6 2 1 2 3 1 3 1 1 2 3 3 4 1 2 3 5 1 5 0 10 3 6 7 1 6 3 8 6 2 4 1 3 3 2 1 1 8 0 6 8 6 6 3 4 1 1 2 2 3 1 3 3 1 1 9 0 8 8 5 1 8 1 3 9 2 1 3 3 1 1 3 3 2 1 3 1 1 5 3 5 3 1 4 4 5 4 3 5 1 7 0 10 4 2 9 3 1 4 4 9 6 1 3 3 2 2 2 3 1 1 5 0 8 7 7 9 7 1 5 6 2 1 1 2 1 2 1 9 0 8 4 1 3 5 8 2 8 1 1 2 1 2 2 1 1 2 2 4 2 4 2 4 3 5 1 9 0 10 1 1 9 9 1 1 1 2 4 4 1 2 1 2 2 1 2 1 2 1 9 0 11 1 7 3 2 9 1 4 6 1 2 7 3 2 2 1 3 3 1 1 2 1 7 0 7 1 5 6 9 1 2 4 1 3 2 1 2 3 3 5 2 1 5 5 3 4 1 8 0 6 5 1 4 8 9 5 1 1 2 2 2 3 2 2 1 7 0 9 1 9 2 3 7 1 6 6 4 2 1 1 2 1 1 3 1 7 0 11 2 3 9 8 5 1 6 4 6 7 9 1 3 3 1 3 2 3 5 2 2 3 3 6 1 7 0 10 3 8 1 2 3 6 2 1 5 9 1 3 1 2 3 1 2 1 8 0 6 8 1 1 8 4 4 1 2 1 2 2 1 2 3 1 9 0 6 1 9 5 6 1 2 1 3 3 3 3 1 1 3 1 2 1 1 5 5 5 3 4 1 5 0 10 9 2 2 5 1 1 1 3 6 5 3 1 3 3 3 1 8 0 6 4 3 9 1 9 1 1 1 1 3 3 2 2 3 1 8 0 8 1 4 1 7 4 9 3 1 3 2 3 2 1 1 1 1 1 1 4 2 1 4 1 6 4 4 3 5 1 5 0 8 7 4 1 1 6 4 8 1 2 3 1 3 3 1 5 0 6 9 1 1 5 6 6 2 2 1 1 1 1 6 0 10 3 7 1 9 7 4 6 2 5 2 1 1 3 2 2 1 4 4 4 1 1 3 5 1 9 0 10 4 2 9 1 8 5 6 1 4 4 2 3 2 2 3 1 1 2 3 1 7 0 11 4 1 3 6 8 5 4 9 8 1 8 3 2 2 2 3 1 1 1 9 0 8 1 9 1 4 3 6 2 5 3 3 2 3 1 2 3 1 1 5 3 3 1 1 3 4 1 8 0 9 8 1 6 6 2 2 7 2 5 1 1 3 2 3 1 1 1 1 5 0 9 4 2 8 6 4 8 5 1 5 2 3 1 2 3 1 8 0 10 4 1 8 1 9 1 4 6 3 9 3 2 2 1 2 3 3 1 1 3 3 1 3 6 1 8 0 8 5 4 9 1 1 9 5 3 2 3 1 1 2 2 1 1 1 9 0 7 6 3 4 1 1 1 6 2 3 2 3 3 1 3 2 1 1 6 0 11 1 1 7 1 3 2 4 8 7 3 7 2 1 3 1 2 3 5 3 3 5 3 4 2 2 1 1 4 5 3 6 1 7 0 6 4 9 1 1 1 9 3 3 2 3 1 3 1 1 7 0 6 2 4 7 1 4 1 1 3 3 1 3 2 2 1 7 0 8 3 5 1 5 3 1 7 9 2 3 1 2 2 1 3 1 5 2 3 2 5 3 6 1 5 0 7 7 2 1 5 6 1 1 2 1 1 3 1 1 9 0 9 4 4 2 7 1 7 4 6 6 3 1 1 3 2 3 1 1 3 1 5 0 6 1 2 1 1 9 1 1 3 1 1 3 5 1 5 1 3 3 3 4 1 9 0 7 3 2 9 1 8 5 6 2 1 3 1 1 2 3 1 1 1 6 0 10 2 5 3 9 2 9 3 8 1 1 3 3 1 1 2 3 1 6 0 8 1 6 9 9 1 7 1 5 1 1 2 3 3 1 2 1 4 3 3 5 1 7 0 10 1 3 9 9 3 6 5 3 7 5 3 1 2 3 2 1 1 1 8 0 6 1 8 6 5 4 2 3 3 2 1 1 3 1 1 1 6 0 8 4 5 1 6 6 6 1 1 1 1 1 3 2 1 1 1 1 3 1 5 1 3 4 5 5 3 3 4 1 9 0 9 1 8 5 6 7 5 9 2 6 3 3 3 3 1 1 1 3 2 1 9 0 6 9 1 6 3 4 2 3 1 1 3 3 2 1 2 3 1 7 0 7 3 9 5 8 1 8 5 2 2 1 1 1 3 2 2 1 1 3 3 4 1 7 0 10 5 6 9 4 1 9 3 8 7 1 2 3 2 1 3 1 1 1 8 0 9 1 6 8 1 1 7 4 1 8 3 2 2 2 3 1 2 3 1 7 0 11 2 6 5 5 8 7 6 6 2 5 1 1 1 3 1 2 2 3 4 2 1 2 3 4 1 9 0 11 9 2 8 6 9 5 6 6 1 1 9 2 1 1 3 1 2 3 2 3 1 5 0 7 4 3 1 8 8 8 5 2 3 1 3 2 1 6 0 7 8 1 5 6 2 2 4 1 2 3 1 3 2 3 1 1 5 3 7 1 5 0 7 7 8 5 6 1 1 2 3 1 2 3 2 1 5 0 8 4 1 7 9 2 3 3 2 2 1 1 2 1 1 6 0 8 8 3 6 2 1 1 2 8 1 1 3 2 1 2 5 4 3 5 5 4 3 3 5 1 9 0 8 4 3 1 5 1 7 3 7 3 1 3 2 3 1 3 1 1 1 6 0 6 1 8 2 3 2 4 2 2 3 1 2 2 1 6 0 10 9 5 1 1 5 4 6 5 1 9 3 2 3 1 1 3 2 1 5 5 2 3 2 6 3 4 5 7 3 5 3 3 7 1 7 0 9 1 2 1 6 3 6 3 3 8 3 3 1 3 1 3 1 1 8 0 7 4 8 1 6 8 1 4 1 1 2 3 1 3 2 2 1 5 0 7 9 5 1 2 1 7 1 2 1 3 1 2 5 4 2 1 4 2 2 3 7 1 7 0 8 1 8 4 8 8 8 1 6 1 1 3 2 2 1 2 1 8 0 9 6 7 1 1 8 5 8 2 8 3 1 1 1 1 3 2 3 1 7 0 11 8 9 5 4 7 5 1 4 8 4 6 3 3 1 3 1 2 3 1 1 5 1 2 2 4 3 7 1 8 0 6 6 8 1 7 1 9 3 2 2 2 3 1 1 2 1 5 0 9 6 7 1 2 8 2 1 6 9 3 1 1 1 2 1 9 0 8 9 5 5 1 1 7 4 6 1 3 2 3 2 2 2 2 1 1 1 1 1 2 1 2 3 5 1 8 0 6 8 5 1 8 5 4 1 1 1 3 3 2 2 3 1 9 0 7 3 6 2 6 3 7 1 2 1 1 2 3 1 1 2 1 1 5 0 11 3 7 6 9 1 9 4 8 1 6 1 1 3 1 1 1 1 5 4 2 3 3 4 1 6 0 6 8 3 1 7 2 9 1 1 2 3 2 1 1 9 0 9 8 7 7 4 9 8 3 1 3 2 3 2 2 1 3 2 1 1 1 6 0 6 1 7 8 1 9 7 1 1 2 2 1 2 3 1 1 4 2 7 4 4 3 3 5 1 5 0 6 1 9 4 4 8 5 2 3 2 1 2 1 5 0 7 1 7 1 7 1 9 1 1 1 2 3 1 1 5 0 8 8 3 1 3 9 7 6 1 1 3 3 2 1 3 2 4 4 2 3 6 1 9 0 8 9 7 1 2 2 5 7 6 1 2 1 3 1 2 2 2 1 1 8 0 8 9 8 2 4 5 7 1 7 3 1 1 3 1 1 2 1 1 5 0 6 7 1 7 3 5 7 1 3 3 2 1 5 1 2 2 3 5 3 7 1 6 0 10 5 3 3 7 2 1 9 9 1 6 1 2 3 2 3 1 1 8 0 11 9 7 9 7 3 3 9 9 6 1 3 2 3 1 1 1 3 2 2 1 5 0 7 9 5 2 9 1 4 9 2 1 2 1 3 1 4 1 2 3 4 5 3 4 1 8 0 11 3 5 2 1 8 5 1 1 6 5 5 2 2 3 2 1 2 2 2 1 6 0 9 1 1 3 8 5 5 1 8 5 1 1 2 3 2 1 1 8 0 6 6 1 1 2 7 4 1 1 3 1 3 2 3 1 1 1 4 5 3 3 4 4 5 3 6 1 9 0 7 3 8 9 1 1 6 7 1 1 1 2 3 3 3 1 2 1 7 0 8 1 7 1 3 1 8 7 6 1 2 1 3 1 2 1 1 6 0 9 7 2 1 2 8 1 1 1 3 1 2 1 3 1 3 1 3 5 2 3 2 3 6 1 9 0 6 9 3 1 1 6 6 1 2 2 3 3 3 3 2 1 1 8 0 8 4 6 4 1 4 2 8 9 1 2 2 3 3 3 2 2 1 9 0 6 2 1 7 6 5 1 2 3 2 1 3 1 2 2 1 1 5 2 2 2 2 3 5 1 5 0 8 9 5 1 3 5 9 9 9 3 2 2 2 1 1 6 0 9 4 1 8 5 4 6 6 9 6 3 1 1 3 1 1 1 8 0 9 5 1 1 7 3 1 1 9 2 1 3 1 1 3 2 1 2 3 5 1 1 3 3 4 1 9 0 7 1 9 1 7 7 2 8 2 2 2 3 1 1 3 2 1 1 9 0 8 9 3 1 5 7 9 7 1 3 1 3 1 3 3 1 1 2 1 5 0 7 2 5 1 1 2 6 5 2 1 1 3 1 5 5 1 1 1 3 2 4 4 5 3 3 7 1 5 0 9 9 8 2 7 1 3 5 8 3 3 3 1 2 3 1 5 0 11 9 8 6 2 3 1 6 5 2 6 1 3 1 1 1 2 1 9 0 6 9 3 1 1 4 8 1 1 3 1 1 3 1 1 2 3 5 2 4 4 5 2 3 4 1 8 0 7 8 4 2 9 9 6 1 3 2 3 1 1 2 3 3 1 6 0 6 1 6 1 7 1 5 2 1 1 2 1 1 1 7 0 9 9 5 8 3 1 1 2 8 6 2 3 2 3 1 2 1 4 5 3 4 3 6 1 6 0 9 5 8 1 3 7 2 4 1 7 2 1 2 2 3 1 1 8 0 8 4 3 6 5 2 8 1 7 2 1 1 2 3 3 1 3 1 7 0 6 1 1 5 2 2 9 3 2 3 3 1 1 1 1 2 4 4 1 1 3 5 1 6 0 10 2 1 6 1 9 9 3 3 1 4 1 1 2 3 3 1 1 7 0 6 3 1 3 9 1 7 1 2 1 1 1 2 1 1 6 0 7 1 2 5 5 1 8 9 1 1 1 1 1 1 2 1 4 2 2 3 7 1 7 0 7 1 2 9 1 1 9 8 3 2 1 3 1 2 1 1 9 0 6 6 1 8 7 1 2 3 2 3 1 1 2 1 2 3 1 5 0 7 2 1 6 4 9 1 7 1 3 1 1 2 3 1 2 5 1 2 5 4 5 1 5 4 3 4 1 9 0 9 6 7 8 9 1 7 7 8 1 3 3 1 2 3 2 3 1 2 1 6 0 11 8 1 6 1 5 9 9 7 2 9 1 2 1 2 3 1 1 1 8 0 10 4 1 4 1 1 2 2 6 4 7 2 2 1 3 3 3 1 1 3 3 2 2 3 5 1 8 0 6 9 1 2 1 6 6 2 3 2 1 2 1 2 1 1 7 0 11 5 1 4 2 1 6 1 8 4 8 8 1 2 1 1 1 2 3 1 5 0 11 8 9 9 3 2 6 3 1 1 3 6 3 1 1 3 1 3 3 3 5 1 3 7 1 5 0 8 9 9 9 4 9 6 1 6 1 1 1 1 3 1 8 0 10 1 1 8 7 2 7 6 9 4 8 1 1 3 3 1 1 1 3 1 9 0 10 7 7 1 5 7 8 6 2 9 5 1 1 1 2 1 2 1 2 2 5 2 2 3 4 2 2 3 5 1 9 0 10 6 2 2 4 1 9 1 7 1 1 1 3 2 2 3 2 2 1 3 1 6 0 7 1 5 9 1 6 2 1 3 3 1 2 1 1 1 8 0 11 1 8 8 5 3 8 8 1 5 8 8 2 2 2 1 3 2 1 1 3 3 1 2 2 3 4 1 9 0 7 4 7 3 1 9 2 8 1 1 3 2 2 1 1 3 1 1 5 0 6 6 9 4 8 8 1 1 2 3 3 3 1 8 0 6 5 5 1 6 7 9 1 1 1 2 1 2 1 1 4 3 5 2 3 7 6 5 5 4 3 5 1 7 0 6 9 7 2 6 2 1 3 3 1 2 3 3 1 1 7 0 10 7 5 2 9 8 3 6 1 3 1 1 3 1 1 1 2 3 1 6 0 9 1 3 9 2 8 3 9 8 6 1 3 1 2 2 3 3 4 1 1 5 3 4 1 9 0 11 9 4 2 6 8 2 9 7 4 6 1 1 2 1 1 2 1 1 1 3 1 5 0 10 9 2 3 5 8 2 1 9 1 1 1 2 2 3 3 1 5 0 9 6 4 1 4 2 3 5 2 3 3 2 2 1 2 2 3 5 3 3 4 1 7 0 6 2 2 9 7 1 9 3 3 1 3 2 3 1 1 6 0 6 8 1 9 7 7 8 3 3 1 1 3 1 1 5 0 8 7 1 6 5 7 9 9 9 1 1 1 3 3 2 5 1 2 3 4 1 6 0 9 9 7 5 1 6 4 5 5 2 3 3 1 3 2 3 1 9 0 9 5 1 9 9 4 5 5 4 3 2 2 2 1 1 1 2 2 2 1 8 0 9 4 9 1 5 1 1 5 8 4 2 1 1 1 3 1 3 1 2 1 1 2 3 4 1 6 0 7 8 6 1 3 1 4 2 2 2 1 2 1 3 1 9 0 7 6 1 7 9 6 2 6 1 1 1 3 1 3 1 2 2 1 8 0 6 4 5 6 4 7 1 2 2 2 3 1 1 3 1 1 5 5 1 4 2 2 1 4 5 3 5 1 7 0 9 4 7 3 6 9 1 1 9 9 2 3 3 1 1 3 3 1 8 0 8 2 4 9 3 2 3 8 1 1 2 3 1 1 1 2 1 1 9 0 7 7 6 3 1 6 2 7 2 1 3 1 3 2 2 3 2 3 5 5 5 3 3 4 1 5 0 8 1 5 6 2 1 4 3 2 1 1 1 2 2 1 7 0 11 2 1 9 7 1 5 6 1 1 3 9 3 1 3 1 1 1 3 1 5 0 6 1 8 2 3 5 6 2 1 3 2 2 1 3 2 4 3 6 1 6 0 6 8 4 1 3 6 7 3 1 1 2 1 2 1 8 0 8 1 8 3 4 7 3 7 1 1 3 3 1 2 1 3 3 1 7 0 7 1 9 1 5 8 9 3 2 1 1 2 1 1 1 4 3 3 2 2 2 3 4 1 8 0 9 5 1 5 2 1 9 2 3 3 3 2 2 3 2 1 2 1 1 7 0 6 3 1 2 6 9 4 2 1 3 2 3 3 1 1 9 0 6 1 2 7 9 9 4 1 3 1 1 3 2 2 1 2 5 3 2 1 2 5 6 1 6 5 8 1 7 3 5 5 3 4 1 8 0 7 6 6 6 3 6 1 7 1 1 2 1 2 1 2 1 1 6 0 10 9 1 9 1 9 8 7 8 3 1 1 1 1 1 2 1 1 8 0 8 7 2 2 8 6 1 1 3 2 3 2 3 2 1 2 1 5 2 3 3 3 7 1 8 0 6 9 6 4 1 1 6 2 1 3 1 2 2 3 3 1 5 0 9 1 5 7 6 1 9 1 4 3 1 2 1 1 2 1 6 0 9 3 8 1 4 1 9 9 2 2 1 3 1 1 2 3 1 5 2 1 5 3 2 3 6 1 6 0 9 9 1 6 5 4 6 6 8 2 3 2 3 2 1 1 1 6 0 6 1 7 7 7 9 5 1 1 1 1 3 2 1 6 0 9 9 3 5 1 9 8 6 1 2 3 3 2 1 2 1 5 4 3 1 3 2 3 7 1 9 0 11 5 2 2 1 8 9 1 8 5 5 7 2 1 1 3 1 1 1 1 3 1 7 0 9 2 3 8 4 1 5 8 5 2 3 1 2 1 1 3 1 1 9 0 8 1 1 6 5 4 8 2 1 2 1 2 2 1 3 2 3 3 3 1 4 2 5 2 1 3 7 1 8 0 7 6 9 8 7 8 1 6 3 1 3 1 3 2 1 1 1 7 0 9 4 1 1 6 7 5 9 6 4 2 1 3 3 3 2 1 1 6 0 10 4 5 1 8 3 4 5 1 8 2 1 3 3 2 1 3 2 3 4 3 2 2 5 1 1 4 1 2 4 4 3 7 1 7 0 9 1 9 7 8 9 8 4 8 1 2 3 2 2 1 3 2 1 8 0 10 6 1 3 3 1 5 4 4 2 9 1 1 3 1 1 1 2 2 1 8 0 8 1 6 3 8 9 4 7 7 3 3 1 2 3 1 1 1 3 1 3 2 3 1 1 3 5 1 6 0 11 7 7 6 6 7 5 1 3 8 5 3 2 3 2 3 2 1 1 7 0 9 1 6 1 9 1 4 9 3 9 1 1 1 3 2 1 1 1 7 0 6 7 4 7 8 2 1 3 3 2 2 1 2 2 2 5 3 1 3 3 5 1 7 0 7 9 4 7 1 4 4 9 2 3 3 3 1 2 2 1 7 0 6 6 8 1 8 6 5 3 3 1 2 2 1 1 1 8 0 10 2 1 8 8 1 6 3 2 9 8 2 2 3 1 2 1 1 1 4 1 2 3 3 3 5 1 5 0 8 3 1 6 5 9 2 2 2 1 1 2 2 3 1 8 0 7 6 1 1 6 8 8 8 1 1 1 2 1 2 3 3 1 8 0 11 1 7 6 7 4 3 4 4 1 3 3 2 3 3 2 2 1 3 1 1 1 2 5 2 5 1 1 5 5 3 3 6 1 7 0 9 6 1 6 1 8 7 3 8 2 2 1 2 1 2 3 3 1 9 0 7 5 1 7 5 6 4 5 1 3 2 1 1 2 1 1 2 1 8 0 8 1 1 2 7 3 9 9 1 1 2 3 1 1 2 1 3 4 2 5 5 5 2 3 5 1 7 0 11 2 3 7 2 4 1 3 7 6 8 4 1 2 1 3 3 1 2 1 5 0 11 4 2 5 5 6 5 2 9 1 6 5 2 1 3 1 3 1 9 0 10 7 7 5 5 4 5 1 3 9 3 1 1 2 2 3 3 1 3 1 2 1 5 3 3 3 6 1 6 0 8 1 7 8 9 2 6 8 3 2 2 1 2 2 1 1 5 0 11 1 8 9 2 3 1 4 1 8 6 6 2 2 1 1 1 1 7 0 9 2 8 2 9 5 5 8 5 1 2 1 3 2 2 1 1 5 2 2 5 3 1 3 5 1 7 0 10 9 4 4 4 6 2 8 1 7 7 1 1 1 3 1 1 1 1 9 0 11 2 7 5 8 3 5 8 1 1 3 4 3 1 2 1 2 1 2 2 1 1 8 0 11 7 7 5 5 9 6 6 4 1 9 8 2 1 2 3 1 2 3 1 3 1 3 5 3 3 7 1 8 0 7 9 4 2 2 1 5 1 1 2 3 2 1 1 2 2 1 6 0 7 8 9 1 8 5 9 1 3 2 2 2 1 3 1 8 0 7 8 4 2 6 1 3 7 1 3 1 3 3 2 1 2 3 1 4 1 5 5 5 7 7 2 5 5 3 7 1 7 0 7 2 2 9 8 1 7 9 1 3 2 1 1 2 3 1 7 0 11 7 1 6 3 1 4 3 1 2 8 5 2 2 1 2 3 1 2 1 8 0 10 5 3 7 8 8 3 5 1 1 3 3 2 3 1 3 1 2 1 2 5 1 5 3 2 2 3 5 1 5 0 10 7 1 8 7 3 1 2 7 1 1 1 2 3 2 2 1 5 0 10 9 2 8 9 6 6 6 4 8 1 2 2 3 2 1 1 6 0 9 2 3 1 3 6 9 3 5 1 2 3 1 1 2 2 4 3 4 3 2 3 5 1 9 0 11 1 9 4 7 7 7 5 1 6 6 1 2 3 3 3 2 3 2 3 1 1 8 0 11 1 7 3 2 4 8 9 2 5 4 5 3 3 1 2 3 3 1 3 1 7 0 6 9 5 1 6 8 6 3 1 2 2 1 2 1 4 4 4 2 4 3 4 1 9 0 11 1 3 9 1 9 3 4 7 5 9 9 1 3 2 1 3 2 1 3 3 1 5 0 10 2 5 9 3 8 3 6 4 1 6 1 1 3 2 1 1 5 0 8 1 2 7 9 5 1 5 6 3 3 2 1 2 2 5 1 2 3 4 1 8 0 6 9 1 1 6 3 7 3 1 3 1 1 3 1 1 1 5 0 6 1 9 9 9 9 8 3 1 1 2 1 1 8 0 10 2 7 8 3 5 1 5 6 6 1 2 2 1 2 3 2 3 1 4 4 2 1 1 6 5 7 1 5 5 3 7 1 9 0 10 2 6 1 4 1 9 4 3 4 5 1 2 2 1 2 3 2 2 1 1 5 0 7 9 4 6 7 7 1 5 1 1 2 2 2 1 8 0 10 3 9 9 8 2 8 7 1 5 9 3 2 2 1 2 3 2 2 4 1 1 4 2 1 2 3 6 1 5 0 9 5 1 4 4 6 4 8 9 8 1 3 3 1 2 1 8 0 9 6 7 1 6 7 1 1 3 4 1 3 2 2 1 1 1 3 1 6 0 6 2 1 6 2 8 1 3 1 3 1 3 2 3 1 4 1 4 3 3 7 1 7 0 7 3 1 2 3 3 1 2 1 3 2 3 2 3 3 1 5 0 9 3 9 3 1 4 1 6 3 3 1 1 3 2 2 1 8 0 10 3 5 5 1 6 7 6 5 4 1 1 2 2 1 1 1 2 3 5 4 4 4 2 2 2 3 5 1 6 0 7 1 2 6 5 7 1 1 3 3 3 2 2 1 1 5 0 7 8 4 3 6 1 1 4 1 3 1 2 2 1 7 0 7 4 7 6 5 9 5 1 3 1 1 1 2 1 3 5 5 4 3 2 3 4 1 6 0 8 6 2 1 9 8 7 6 1 2 2 2 1 1 1 1 8 0 9 1 2 5 4 5 9 4 7 8 1 3 2 2 3 3 1 2 1 8 0 9 1 9 1 6 1 1 5 8 1 3 2 1 3 3 2 2 1 3 4 3 3 2 3 1 4 4 5 4 3 6 1 7 0 8 4 2 1 4 8 4 7 4 3 2 3 1 1 3 1 1 7 0 6 2 5 1 8 1 1 3 2 3 3 3 1 2 1 6 0 7 3 8 5 2 3 1 1 1 1 2 3 1 1 1 1 1 5 5 1 3 4 1 7 0 7 1 7 1 8 9 2 6 1 3 1 3 2 2 1 1 5 0 6 7 3 9 1 6 9 2 2 1 3 3 1 8 0 11 8 1 6 5 8 4 4 2 8 8 9 1 1 3 1 1 1 2 1 1 2 2 5 3 6 1 8 0 10 8 1 8 9 6 5 6 8 1 6 1 3 3 3 1 3 2 1 1 5 0 9 1 8 6 2 1 6 9 5 3 2 2 2 1 1 1 8 0 11 8 1 4 3 6 9 8 3 8 4 8 3 1 3 1 2 1 3 1 5 5 4 2 2 2 3 7 1 6 0 11 4 2 1 5 3 2 3 6 8 4 2 3 2 1 1 1 1 1 6 0 7 7 2 3 4 8 1 9 3 1 1 3 1 1 1 5 0 11 9 9 4 2 3 6 2 8 4 1 3 1 3 1 2 1 5 3 1 4 1 5 4 3 7 1 9 0 9 5 4 8 1 3 2 1 8 9 1 3 3 2 1 2 3 2 2 1 5 0 9 2 2 7 1 1 2 1 6 3 1 3 1 3 1 1 6 0 6 5 9 1 5 8 5 3 3 2 1 2 1 2 3 5 5 2 2 5 6 7 4 7 5 4 3 6 1 6 0 10 9 1 5 1 1 1 3 1 9 7 1 2 1 2 3 1 1 6 0 11 8 8 6 1 6 5 3 5 1 1 5 3 1 2 1 3 2 1 9 0 7 3 1 2 3 5 9 8 2 1 3 2 2 3 1 2 2 1 1 1 1 3 3 3 5 1 6 0 11 4 1 1 6 8 8 3 6 9 4 1 2 2 1 2 1 2 1 7 0 10 1 8 8 4 4 9 5 1 6 1 2 3 2 1 1 2 2 1 8 0 10 4 2 2 2 6 1 7 5 7 6 2 3 3 1 2 1 1 1 1 3 1 2 5 3 7 1 7 0 6 3 9 5 1 4 9 1 3 3 2 1 1 2 1 9 0 8 5 1 5 6 2 2 9 5 1 3 1 2 3 1 1 1 2 1 5 0 8 9 1 2 9 5 2 1 2 2 1 1 1 1 2 2 3 2 5 2 4 3 4 1 6 0 8 1 8 2 8 9 2 8 2 3 1 3 2 3 2 1 9 0 6 1 8 5 7 1 5 3 1 1 1 2 2 3 2 1 1 8 0 6 8 1 1 6 4 2 2 1 1 1 3 2 1 2 2 2 3 4 3 6 1 9 0 10 8 3 5 9 7 9 5 1 4 6 1 2 2 1 1 2 3 1 2 1 5 0 6 5 2 1 7 1 9 1 1 3 1 1 1 7 0 8 2 7 7 9 9 9 9 1 3 1 2 3 2 2 3 1 2 5 5 2 3 3 2 4 5 7 3 3 6 3 4 5 3 4 1 9 0 10 6 1 3 1 6 4 7 5 4 9 3 1 1 1 2 1 2 2 3 1 5 0 7 3 9 2 2 3 1 1 1 1 3 3 3 1 7 0 10 8 6 7 6 8 1 3 4 6 1 1 1 3 1 3 2 2 2 1 5 1 3 4 1 8 0 10 8 6 7 8 1 3 3 9 1 1 3 2 3 1 2 2 2 1 1 8 0 7 1 5 1 7 7 6 2 1 2 3 3 1 2 3 1 1 6 0 9 3 6 8 8 1 2 1 9 8 3 2 3 1 1 1 1 2 2 3 3 7 1 8 0 7 8 7 7 1 7 1 4 1 3 3 2 1 3 1 2 1 6 0 9 4 6 2 7 4 1 1 1 1 3 3 3 3 2 1 1 5 0 9 9 1 9 2 1 2 6 3 9 3 2 1 2 2 3 4 1 2 2 1 1 3 7 1 6 0 9 5 7 6 9 6 1 5 3 1 1 3 3 3 3 2 1 6 0 9 3 1 7 2 1 8 4 3 7 2 1 3 1 1 2 1 8 0 8 4 5 8 1 6 7 5 4 1 3 1 3 1 1 2 1 2 3 1 3 1 2 3 2 3 5 4 3 4 3 3 4 1 8 0 7 6 2 2 6 8 1 9 2 1 3 1 2 1 2 2 1 5 0 11 5 1 5 5 5 1 8 2 1 2 7 2 2 3 1 1 1 6 0 9 6 1 8 9 1 1 1 6 5 1 3 1 2 1 3 2 4 3 5 3 7 1 8 0 10 3 1 2 5 6 3 6 1 9 8 2 1 1 2 3 1 3 1 1 6 0 7 9 1 5 6 1 6 1 2 1 1 1 2 1 1 6 0 9 7 1 3 7 1 1 6 7 6 2 2 1 1 3 1 4 2 3 5 3 3 3 3 5 1 5 0 8 4 6 7 4 9 4 8 1 1 1 1 3 1 1 5 0 11 9 7 5 1 8 4 1 1 4 2 1 3 2 2 1 1 1 7 0 10 8 7 3 1 1 1 7 6 4 5 1 1 1 1 2 3 2 2 2 3 1 2 3 5 1 5 0 7 9 6 8 3 1 5 6 1 1 3 1 2 1 8 0 11 1 8 2 1 4 6 4 4 3 6 1 2 3 2 1 1 1 2 1 1 9 0 7 7 3 4 5 9 1 9 1 1 1 3 3 1 2 1 1 2 1 5 3 3 4 2 2 5 4 3 5 1 7 0 10 3 8 3 1 9 7 5 3 1 9 1 2 1 1 2 1 2 1 7 0 11 5 5 1 8 6 6 8 6 4 7 6 1 2 1 1 1 3 2 1 9 0 8 1 6 2 8 8 5 9 2 1 3 1 3 1 1 1 2 2 1 2 4 2 1 3 5 1 7 0 9 1 9 9 4 8 1 8 4 2 3 1 1 1 3 1 1 1 8 0 10 7 4 4 4 1 8 3 8 1 3 3 3 2 1 1 3 2 1 1 6 0 8 1 3 1 8 2 9 8 3 2 1 1 2 2 3 1 3 4 1 5 3 5 1 5 0 8 7 2 1 6 9 5 6 3 2 3 1 2 1 1 6 0 7 2 9 7 1 6 1 6 1 3 1 3 3 1 1 5 0 8 7 5 3 4 6 5 2 1 3 3 1 1 1 4 2 4 2 1 3 4 1 5 0 8 7 1 6 1 9 1 1 3 2 2 3 2 1 1 8 0 8 1 6 1 8 4 3 6 2 1 1 3 3 1 1 3 2 1 6 0 8 4 5 1 2 5 6 7 8 1 1 3 2 2 1 1 1 2 1 3 7 1 5 0 9 6 5 2 4 5 1 3 5 5 1 3 1 1 3 1 8 0 8 1 4 1 1 9 6 8 2 3 1 2 1 1 3 3 1 1 8 0 9 4 9 7 4 1 7 9 5 5 2 1 1 2 3 2 3 2 2 4 2 5 3 2 4 1 1 5 1 5 5 3 4 1 5 0 11 8 8 8 4 6 1 9 2 5 9 7 1 2 1 3 3 1 6 0 6 8 2 5 6 7 1 3 3 1 1 3 3 1 7 0 9 1 3 6 6 3 2 5 6 6 2 3 1 3 2 1 1 3 2 4 4 3 5 1 5 0 11 3 7 7 4 1 9 3 1 1 1 8 2 1 3 1 2 1 7 0 8 2 3 2 4 3 3 2 1 1 1 1 2 1 1 3 1 5 0 8 1 9 3 1 8 2 9 7 3 1 2 2 1 2 3 5 4 2 3 7 1 8 0 9 5 7 2 8 6 8 4 1 1 2 1 3 1 1 2 1 3 1 7 0 10 7 7 6 7 5 4 5 1 1 5 2 1 1 1 1 2 2 1 8 0 6 5 9 3 5 4 1 1 3 3 1 2 2 2 1 3 4 4 2 2 1 2 3 6 1 9 0 8 7 6 6 2 5 6 8 1 2 2 1 3 1 3 3 3 2 1 5 0 7 9 3 1 2 9 4 3 1 2 1 2 1 1 6 0 9 6 5 6 4 9 1 7 8 6 1 1 1 2 3 3 3 4 1 3 1 2 3 7 1 8 0 9 4 5 8 4 8 1 4 3 8 1 3 2 2 3 1 2 2 1 8 0 10 3 8 4 8 5 8 3 9 1 8 1 1 2 3 3 3 3 1 1 7 0 11 8 7 5 1 1 1 2 6 2 3 1 1 1 1 1 2 2 3 4 5 5 2 5 3 5 2 4 6 1 5 4 4 3 5 1 9 0 11 8 1 1 1 9 1 7 7 7 1 1 2 1 1 1 3 1 1 2 3 1 5 0 8 1 6 7 4 7 2 6 1 1 1 1 2 2 1 5 0 6 4 8 1 8 7 1 3 1 2 2 3 5 2 3 2 1 3 4 1 8 0 9 4 6 1 4 5 5 1 3 1 3 2 1 2 1 2 3 3 1 9 0 9 5 3 4 4 7 1 1 2 4 3 1 2 2 3 1 1 2 3 1 7 0 7 8 8 1 6 9 2 3 1 1 3 3 1 2 1 1 3 2 3 3 6 1 6 0 11 5 4 4 2 6 3 4 1 6 6 3 2 3 1 3 3 2 1 9 0 9 9 1 6 5 8 1 1 2 1 2 1 2 2 3 1 2 3 2 1 8 0 8 2 2 8 1 4 2 3 1 1 1 1 3 3 2 1 1 1 2 3 2 4 5 3 7 1 9 0 10 8 7 9 5 1 9 7 4 6 1 1 1 1 2 1 1 2 3 1 1 5 0 8 1 3 3 9 1 6 1 2 2 2 2 1 1 1 7 0 11 5 6 6 7 2 8 7 9 5 5 1 2 2 1 1 1 3 1 1 2 1 1 5 1 4 5 2 4 3 5 4 3 6 1 6 0 9 5 5 2 1 4 3 4 7 9 2 2 3 1 1 2 1 9 0 9 2 1 3 4 1 1 7 7 3 3 1 1 2 2 1 1 1 2 1 7 0 11 2 1 9 9 1 7 7 1 3 7 8 1 3 1 3 2 1 1 4 1 5 2 5 3 3 5 1 5 0 9 8 1 4 2 4 4 3 9 1 1 3 3 1 2 1 6 0 6 5 6 3 1 4 1 1 2 1 1 3 2 1 8 0 10 1 6 9 4 6 4 4 9 6 8 3 2 2 3 1 3 2 1 4 3 1 3 1 3 5 1 5 0 11 5 1 5 2 3 3 5 1 6 4 9 3 2 1 2 1 1 8 0 6 8 2 7 8 7 1 2 3 3 2 1 3 1 1 1 9 0 10 9 8 2 1 7 6 2 9 9 8 1 3 2 2 1 3 1 3 2 1 4 4 1 2 3 7 1 6 0 6 7 8 2 1 9 5 3 2 1 1 3 1 1 6 0 7 8 7 4 4 1 3 9 3 1 1 1 2 1 1 9 0 9 1 9 2 4 9 3 1 1 3 1 2 3 1 3 3 1 2 1 1 5 2 2 4 5 2 3 4 1 5 0 11 6 1 2 5 3 3 6 8 5 1 2 3 1 1 3 3 1 7 0 11 5 4 9 1 2 4 8 1 3 4 1 2 3 2 1 3 3 3 1 5 0 7 3 3 5 8 2 5 1 2 3 1 3 1 4 4 3 1 3 1 2 1 6 4 4 6 3 4 5 3 4 1 7 0 8 4 5 8 1 8 2 4 2 1 2 3 3 3 1 3 1 7 0 10 2 7 4 4 9 1 4 7 1 5 1 2 1 2 3 1 1 1 8 0 11 5 7 9 4 9 1 7 3 1 8 4 3 3 1 1 1 1 3 2 3 4 3 3 3 7 1 8 0 7 7 1 4 7 3 8 1 1 1 1 3 1 3 2 2 1 7 0 10 2 2 1 3 7 7 4 4 1 5 2 3 1 1 1 1 1 1 6 0 9 5 5 4 7 9 3 7 9 1 1 1 1 3 3 3 2 3 1 5 2 5 4 3 6 1 7 0 11 7 8 4 2 7 1 5 3 3 5 2 2 3 1 1 3 3 2 1 5 0 8 9 1 1 1 7 3 5 4 1 1 3 1 2 1 6 0 9 4 9 1 1 4 2 2 2 5 1 1 1 3 1 2 3 4 3 1 1 2 3 5 1 5 0 9 1 1 1 2 5 7 2 3 2 3 2 3 1 1 1 5 0 8 1 4 5 6 3 4 5 5 1 3 1 2 2 1 8 0 6 1 7 9 4 1 5 2 3 1 3 1 1 1 2 1 1 3 4 4 1 5 5 4 2 5 3 3 4 1 9 0 11 4 9 3 8 8 1 7 3 4 7 8 2 3 3 2 1 3 3 1 1 1 5 0 10 6 1 8 5 1 4 6 4 2 8 1 2 1 2 3 1 9 0 8 1 3 1 4 3 8 9 3 3 1 1 1 3 3 3 3 1 1 3 3 3 3 6 1 5 0 10 7 5 7 4 9 2 6 8 9 1 2 3 2 1 1 1 9 0 7 6 8 5 1 2 1 5 3 2 1 3 3 1 1 2 3 1 6 0 10 6 6 8 5 1 6 1 5 8 6 3 3 1 3 1 3 5 3 5 2 3 1 3 6 1 5 0 11 4 5 1 7 3 6 4 4 1 2 2 1 1 2 3 1 1 7 0 9 1 3 4 8 9 5 9 6 6 1 1 1 1 2 2 1 1 8 0 10 7 7 2 5 9 8 6 3 1 4 1 3 3 1 3 1 1 3 1 1 4 5 2 5 3 4 1 8 0 11 4 1 4 9 3 1 3 4 6 2 8 1 3 3 2 3 1 2 1 1 9 0 6 1 7 1 6 4 3 2 3 1 3 3 3 1 2 2 1 7 0 8 1 6 5 9 1 1 3 3 1 3 2 3 1 1 2 4 4 1 5 3 4 1 5 0 9 5 9 4 2 1 8 1 4 9 1 1 3 1 3 1 7 0 8 8 4 1 9 2 6 3 3 1 3 1 3 1 2 1 1 9 0 6 1 1 8 4 3 4 3 3 3 1 3 3 3 1 2 1 4 3 2 2 5 4 5 4 3 6 1 7 0 6 3 1 1 1 5 9 1 1 1 3 3 1 1 1 6 0 10 9 4 6 2 7 5 1 6 6 3 3 3 3 1 1 3 1 7 0 10 7 4 7 2 2 1 9 1 6 2 1 3 3 1 1 2 3 4 2 3 1 5 5 3 5 1 5 0 6 9 5 5 7 8 1 1 1 1 2 1 1 6 0 11 5 2 2 2 5 6 1 3 9 2 4 2 1 2 1 2 3 1 8 0 8 2 4 1 3 1 7 1 7 2 1 1 3 3 3 3 3 3 2 2 4 4 3 7 1 8 0 7 6 5 1 4 2 9 5 2 1 2 2 1 2 1 2 1 9 0 10 2 3 9 9 6 6 3 5 3 1 2 3 3 1 3 3 2 3 2 1 5 0 6 2 2 1 9 3 3 3 2 1 1 1 4 2 4 4 2 4 3 3 5 1 6 0 6 8 6 1 9 6 5 2 1 1 2 1 3 1 7 0 9 8 2 5 5 1 6 8 6 3 2 1 3 3 1 3 3 1 7 0 8 8 6 3 9 4 7 1 8 3 3 1 2 3 2 1 3 5 5 2 1 3 6 1 7 0 7 4 7 8 7 1 1 3 3 1 1 3 3 1 2 1 6 0 7 6 4 6 4 8 1 2 1 2 1 1 2 2 1 9 0 7 7 7 5 1 8 7 6 1 2 1 3 1 3 3 1 3 1 4 5 3 5 2 3 7 3 5 4 5 3 6 1 9 0 7 1 1 9 9 4 4 2 2 1 2 1 1 2 1 3 3 1 9 0 10 4 4 2 1 1 9 8 8 1 1 3 1 2 1 3 2 1 3 1 1 6 0 10 4 1 7 1 5 3 8 7 3 5 1 2 1 3 3 2 1 2 4 3 4 3 3 4 1 8 0 11 1 3 1 5 3 8 4 9 1 1 9 2 2 2 3 3 1 3 1 1 5 0 10 1 6 3 1 5 7 8 3 3 1 2 1 2 2 2 1 9 0 9 8 1 8 5 9 5 7 9 1 1 1 2 2 2 3 1 2 2 2 3 3 1 3 5 1 6 0 6 3 1 1 9 3 5 1 2 1 2 1 2 1 8 0 6 9 1 2 2 9 3 3 1 3 3 1 3 3 3 1 8 0 6 7 1 1 1 5 3 1 1 1 3 2 3 1 3 3 1 2 1 3 3 5 1 5 0 6 2 1 6 7 5 2 1 1 1 3 3 1 6 0 8 9 1 2 9 2 1 5 3 3 1 3 1 1 2 1 6 0 10 4 7 6 1 1 6 3 1 3 8 3 3 2 1 1 2 1 3 2 3 4 5 6 2 3 6 5 3 3 5 1 5 0 8 3 4 6 5 8 1 8 1 1 3 1 1 2 1 6 0 7 6 1 3 3 2 9 5 1 1 2 3 1 2 1 7 0 10 1 2 2 8 8 8 2 3 1 1 2 2 3 3 3 1 2 2 1 2 2 2 3 7 1 5 0 10 3 6 1 8 5 7 6 9 2 7 1 1 3 2 2 1 8 0 9 2 3 3 9 1 9 6 8 1 2 3 1 2 3 3 2 2 1 6 0 10 9 4 5 2 3 1 3 5 1 8 2 1 2 3 3 2 2 1 2 3 1 5 2 3 4 1 8 0 7 6 8 1 6 9 7 4 2 3 3 1 3 1 2 1 1 7 0 6 8 1 7 5 1 5 2 2 3 2 2 2 1 1 8 0 10 1 2 9 8 7 5 3 9 6 1 3 2 1 1 1 2 1 2 1 1 1 2 3 6 1 6 0 6 7 8 4 6 5 1 1 1 2 1 1 1 1 9 0 8 1 5 6 3 8 7 1 6 2 1 3 3 1 2 3 3 1 1 5 0 11 1 1 6 8 9 6 1 2 4 2 2 2 3 1 1 3 1 2 5 3 4 5 3 5 1 7 0 6 1 7 1 1 8 1 2 2 3 2 1 3 3 1 5 0 7 5 1 9 3 6 1 4 2 1 3 1 1 1 6 0 11 7 9 3 1 2 1 1 1 1 1 5 2 2 1 3 2 1 2 3 3 3 5 5 1 6 5 3 3 6 1 6 0 8 6 1 9 2 8 1 6 7 2 1 3 2 1 1 1 5 0 7 7 3 2 8 4 6 1 1 1 2 3 2 1 7 0 8 8 8 2 3 2 1 1 6 3 3 1 1 3 3 2 1 4 2 2 3 4 3 6 1 6 0 8 5 8 5 3 1 4 2 9 3 2 2 2 1 3 1 6 0 7 5 5 3 5 1 3 8 1 1 3 1 3 3 1 9 0 7 2 6 2 1 2 2 7 1 1 1 2 1 3 2 3 2 4 2 3 4 5 2 3 5 1 8 0 9 1 2 9 9 2 2 4 9 2 1 2 2 2 1 3 3 2 1 8 0 8 1 9 8 7 1 6 8 9 3 3 3 1 2 3 3 1 1 9 0 7 3 2 8 1 3 4 3 1 3 1 3 2 1 1 3 2 2 5 3 1 4 3 4 1 8 0 6 1 4 6 5 9 1 1 1 1 1 2 1 3 3 1 6 0 8 1 9 4 8 3 6 9 1 1 2 1 3 1 2 1 5 0 8 9 3 4 1 3 4 9 1 3 3 1 2 1 5 4 2 5 3 6 1 6 0 7 1 2 6 3 7 7 5 2 3 1 2 1 1 1 9 0 10 1 6 3 1 5 1 5 7 2 9 3 1 2 2 3 1 2 1 1 1 8 0 8 4 5 8 2 7 1 8 9 2 2 1 3 1 3 3 1 4 5 1 1 3 2 3 5 4 3 3 1 6 2 5 3 3 7 1 6 0 6 1 4 1 8 5 5 1 3 1 2 1 1 1 8 0 10 2 5 1 4 6 8 2 2 7 7 2 1 1 1 1 3 3 1 1 6 0 10 3 1 1 7 1 1 1 5 6 6 2 1 3 3 1 1 3 2 3 4 4 3 1 3 6 1 9 0 11 5 2 7 2 1 8 2 5 4 1 5 3 1 1 1 3 3 2 2 2 1 8 0 7 4 1 8 1 4 4 8 2 3 1 1 2 3 2 2 1 5 0 6 7 3 7 1 3 4 2 1 3 2 3 5 1 4 5 4 4 3 6 1 6 0 7 8 4 1 1 3 1 1 2 1 1 2 1 3 1 6 0 7 9 2 5 1 6 5 9 1 1 1 1 1 1 1 7 0 8 6 7 6 1 7 5 3 8 2 2 3 2 3 1 3 3 2 1 3 2 3 3 7 1 7 0 10 3 1 7 7 1 4 5 4 1 8 2 1 3 1 3 2 2 1 9 0 9 5 5 4 4 6 4 1 4 8 1 2 1 2 1 3 3 3 1 1 5 0 6 1 3 7 7 4 6 2 1 2 3 1 2 4 3 3 2 4 2 3 5 1 5 0 8 1 2 8 1 6 9 6 4 3 3 1 2 1 1 8 0 6 4 1 5 2 3 1 1 3 2 1 1 2 3 2 1 6 0 9 8 9 7 6 5 1 2 6 6 1 1 2 3 1 2 3 1 1 5 5 7 2 4 4 3 3 6 1 5 0 8 7 6 4 9 7 3 1 2 2 1 3 1 1 1 5 0 8 8 1 6 5 6 8 9 4 1 1 3 3 3 1 6 0 7 5 6 1 9 4 4 3 1 3 2 2 1 3 1 1 2 4 4 3 3 5 1 5 0 6 6 5 8 7 1 5 1 1 3 2 3 1 8 0 10 9 3 1 7 3 8 7 6 9 8 1 1 2 2 3 3 1 1 1 9 0 11 6 3 1 4 9 4 4 8 8 1 2 1 3 1 2 1 1 2 1 2 2 4 2 2 5 3 4 1 8 0 10 2 1 2 7 1 6 5 2 1 8 2 1 2 2 2 1 2 2 1 6 0 8 4 3 7 8 1 1 7 5 3 1 3 1 1 2 1 9 0 9 8 8 6 1 4 8 5 9 4 1 1 2 3 3 3 3 1 1 1 3 1 1 3 5 1 8 0 8 8 6 4 3 9 1 7 1 2 3 2 1 1 2 2 3 1 7 0 10 9 2 7 1 7 9 2 7 5 1 3 2 2 3 1 1 3 1 8 0 6 2 6 6 1 7 5 1 3 1 1 3 2 1 3 2 5 1 4 3 5 4 5 5 5 3 5 1 7 0 10 1 9 6 7 4 7 5 6 4 5 3 2 3 1 3 3 1 1 6 0 11 1 8 1 2 3 1 2 8 4 6 7 2 3 1 1 1 1 1 9 0 10 8 7 8 5 5 4 8 1 3 3 3 1 1 2 1 2 2 1 1 3 5 3 3 3 3 4 1 6 0 7 4 3 9 5 1 7 8 1 1 3 1 3 1 1 7 0 7 7 1 4 6 4 1 8 2 2 3 2 1 3 3 1 9 0 11 8 7 1 2 7 9 3 9 4 1 8 3 2 1 3 3 2 1 2 3 1 3 3 2 3 7 1 9 0 7 1 1 9 9 9 4 4 2 3 2 3 3 1 2 2 3 1 7 0 6 1 9 1 3 1 2 1 1 1 1 3 3 2 1 8 0 10 7 7 6 6 1 2 3 4 5 3 2 3 1 3 1 1 2 3 4 2 2 4 3 1 3 3 4 1 5 0 9 8 2 1 1 8 1 9 4 8 2 2 1 1 3 1 9 0 10 6 4 1 4 4 9 5 4 4 8 3 2 2 1 2 1 1 2 1 1 6 0 8 2 8 3 4 1 7 2 3 1 3 2 1 3 3 4 5 2 1 3 6 1 7 0 8 7 8 4 7 6 9 1 3 2 2 3 3 3 1 3 1 7 0 11 1 3 7 4 6 6 4 7 1 8 1 3 1 2 1 2 1 3 1 7 0 9 2 5 8 6 1 6 1 4 7 3 3 1 2 1 2 2 1 1 5 3 3 3 3 1 4 6 4 4 5 3 4 1 6 0 6 2 3 6 1 6 7 2 2 1 2 1 1 1 9 0 11 3 5 1 9 1 8 3 3 3 3 4 1 1 3 3 3 3 1 1 2 1 7 0 8 1 6 3 8 9 8 8 5 2 2 2 1 1 1 1 2 4 1 3 3 4 1 8 0 6 5 9 7 6 7 1 1 1 2 1 3 3 1 2 1 6 0 6 3 1 5 8 1 8 3 3 2 1 1 1 1 8 0 6 3 7 1 6 2 8 3 3 1 3 3 1 3 2 2 3 2 3 3 7 1 6 0 8 2 4 5 4 3 4 1 4 1 3 3 3 1 1 1 6 0 9 2 6 1 2 1 2 4 2 1 2 3 1 3 3 3 1 6 0 9 2 5 1 8 6 6 4 1 8 3 1 3 3 1 1 4 2 1 2 2 5 2 3 4 1 7 0 10 5 1 2 5 7 6 1 1 2 4 2 3 1 3 2 2 3 1 9 0 11 7 5 1 7 7 9 1 9 2 2 3 3 1 3 1 1 1 3 3 1 1 8 0 11 1 7 7 1 3 6 3 2 6 6 6 1 3 2 1 2 1 2 2 4 5 2 1 5 1 1 5 2 5 3 3 6 1 8 0 8 5 6 8 1 1 3 4 8 2 1 1 3 1 1 2 2 1 5 0 10 9 2 7 8 1 2 3 6 5 8 3 2 1 3 1 1 5 0 6 9 1 6 9 9 3 1 2 2 1 1 3 5 3 2 1 2 3 7 1 7 0 9 8 9 4 7 1 7 1 9 1 3 2 2 2 3 2 1 1 5 0 10 8 9 4 1 4 8 6 2 8 6 3 2 1 2 3 1 9 0 8 1 2 1 5 1 5 4 6 1 1 3 3 2 1 3 1 1 1 1 5 4 2 2 4 3 5 1 6 0 9 5 1 6 2 1 7 7 8 7 3 1 3 3 1 1 1 9 0 11 8 1 2 6 7 5 6 9 1 9 6 3 1 1 2 2 3 3 3 1 1 9 0 10 1 2 5 6 5 3 6 7 1 3 1 3 3 3 1 1 2 1 1 1 1 1 2 2 3 4 1 9 0 6 4 6 9 8 1 1 1 1 3 3 3 3 1 1 1 1 9 0 10 9 1 7 3 8 8 9 4 8 3 1 1 3 1 1 2 3 1 1 1 8 0 7 6 8 1 2 6 1 6 3 2 3 1 1 1 1 3 2 1 3 1 3 4 1 5 0 8 1 5 8 6 1 7 8 1 1 3 3 1 1 1 6 0 6 8 1 8 3 7 9 2 1 2 3 1 3 1 7 0 8 1 2 1 8 9 4 6 1 3 1 2 3 3 1 3 3 3 1 1 3 7 2 5 3 3 4 1 8 0 7 1 5 5 1 3 7 2 2 1 1 3 3 3 2 3 1 7 0 7 3 3 1 1 6 8 2 1 1 3 3 3 2 1 1 7 0 8 2 6 4 7 2 1 3 9 1 3 2 1 3 2 2 2 1 5 3 3 4 1 5 0 7 9 9 5 8 8 9 1 3 2 1 1 2 1 8 0 6 1 8 4 3 3 3 3 1 1 1 3 1 3 2 1 9 0 9 9 9 5 7 1 1 5 8 1 2 1 2 2 1 2 2 1 2 5 1 4 4 3 4 1 7 0 11 3 2 9 7 1 8 9 5 2 9 3 3 1 3 2 2 2 1 1 9 0 6 1 5 5 6 5 5 3 2 1 2 3 1 2 3 1 1 7 0 7 1 3 2 1 5 1 3 1 3 1 1 1 2 1 2 2 4 1 3 7 1 6 0 7 2 4 2 7 8 1 8 3 1 3 2 1 2 1 5 0 10 3 4 7 6 5 6 5 9 1 6 1 1 1 1 3 1 8 0 6 2 2 9 6 1 3 3 3 1 3 2 3 3 2 5 5 5 2 4 2 3 3 5 1 5 0 8 9 5 1 3 8 1 7 4 1 2 1 3 1 1 6 0 9 1 7 3 9 3 3 3 1 3 3 3 1 1 2 3 1 6 0 10 1 6 3 9 2 6 1 4 6 1 2 2 1 3 1 3 2 2 4 3 5 5 5 6 4 7 6 3 5 4 3 4 1 9 0 6 3 1 5 1 3 3 2 1 3 2 3 3 3 1 3 1 7 0 9 4 1 7 2 3 5 2 9 6 1 2 1 3 1 1 1 1 6 0 6 4 3 1 5 2 3 1 1 1 1 2 2 2 4 5 1 3 5 1 6 0 11 2 5 6 5 3 1 1 4 3 7 6 1 2 1 3 2 1 1 5 0 6 2 6 1 7 3 1 1 3 1 1 3 1 9 0 9 1 8 9 8 1 2 4 5 5 2 3 1 1 3 1 1 1 3 2 3 2 4 2 3 5 1 5 0 6 6 7 8 1 6 5 2 2 1 1 3 1 6 0 8 4 2 9 3 2 4 1 6 3 1 3 2 3 3 1 8 0 6 5 9 8 3 1 4 3 1 2 3 3 1 3 3 5 2 1 1 2 3 4 1 7 0 6 7 1 8 7 7 9 1 2 3 1 2 3 1 1 5 0 10 2 2 3 3 5 3 4 1 6 5 1 1 3 3 1 1 9 0 6 4 9 5 6 1 9 2 1 1 2 1 1 1 2 1 1 2 3 3 3 5 1 7 0 6 1 7 4 2 3 3 1 1 2 2 1 1 2 1 7 0 11 7 1 6 9 6 7 8 2 6 2 1 1 1 1 2 2 3 2 1 6 0 7 6 3 5 1 5 3 8 2 3 2 3 1 1 4 4 3 1 1 7 2 5 7 4 4 3 6 1 6 0 9 1 5 5 7 9 3 1 4 7 1 1 2 1 2 1 1 9 0 7 6 1 2 2 9 8 5 2 3 1 2 3 1 1 1 2 1 7 0 6 5 7 1 8 4 3 1 1 3 2 2 1 1 5 2 1 5 5 1 3 7 1 5 0 10 4 4 6 1 1 2 3 3 5 4 2 3 1 2 1 1 5 0 11 2 1 7 4 3 7 1 5 9 2 1 1 2 2 2 2 1 6 0 7 8 3 2 1 7 9 5 3 3 3 1 2 1 5 4 5 1 3 1 1 3 6 1 9 0 7 7 6 1 7 6 2 4 3 2 3 2 1 3 1 3 1 1 7 0 11 6 9 7 5 5 1 7 9 2 7 1 2 1 2 2 1 3 3 1 5 0 7 3 6 5 5 1 3 9 1 1 2 1 1 3 3 2 3 2 2 3 7 1 5 0 10 5 1 5 6 3 7 1 9 3 5 3 1 2 1 2 1 7 0 10 7 4 4 2 1 1 3 3 1 2 1 1 1 3 2 2 2 1 9 0 11 7 7 1 2 8 9 7 3 6 5 5 1 1 3 3 3 3 2 3 3 3 4 4 4 2 4 2 2 5 6 3 5 4 3 4 1 8 0 11 5 7 6 2 7 1 4 5 4 9 6 1 1 3 3 2 1 3 1 1 5 0 6 1 7 5 6 8 8 2 2 1 3 1 1 6 0 9 2 9 2 9 5 1 4 9 7 2 3 3 2 1 1 3 1 2 2 3 4 1 7 0 7 4 9 5 6 7 1 1 3 2 3 1 2 2 2 1 5 0 9 8 4 9 7 4 1 2 3 5 2 2 1 3 1 1 9 0 6 1 5 7 7 2 4 3 2 2 1 3 1 1 1 1 2 5 2 4 3 6 1 6 0 10 4 5 6 9 1 2 4 5 6 5 1 3 2 1 1 3 1 7 0 8 9 1 4 2 6 6 4 6 2 1 3 1 1 3 1 1 8 0 7 2 7 1 4 1 1 6 1 1 2 1 3 3 2 3 2 1 5 1 1 3 3 5 1 6 0 7 7 7 2 1 5 6 9 2 1 3 1 2 1 1 5 0 6 9 5 7 1 4 1 3 1 1 2 1 1 6 0 10 8 8 3 4 1 5 6 7 8 8 3 3 1 2 1 1 3 5 3 1 5 3 5 1 5 0 7 1 7 5 9 1 7 3 1 3 1 1 1 1 7 0 6 3 8 1 5 1 5 3 2 1 1 1 1 1 1 7 0 6 1 5 2 5 6 1 2 1 1 1 3 3 1 2 2 5 2 1 5 3 3 3 5 5 3 4 1 8 0 9 2 3 2 9 2 1 9 4 1 2 2 1 1 1 2 3 3 1 6 0 9 5 1 5 2 1 5 3 7 9 2 2 2 2 1 1 1 5 0 10 6 7 7 5 1 5 7 9 2 1 2 1 1 3 1 4 2 4 1 3 5 1 6 0 8 2 7 1 6 9 1 1 1 3 2 1 3 3 3 1 7 0 7 3 3 5 3 1 1 4 1 2 2 3 1 1 2 1 5 0 6 6 1 6 7 5 9 1 1 2 3 1 1 3 4 1 5 3 6 1 8 0 11 6 9 9 9 1 9 3 3 8 7 1 1 1 1 1 1 3 2 3 1 6 0 6 3 1 6 1 9 8 1 2 1 1 2 2 1 8 0 7 5 1 8 5 9 8 2 1 1 2 1 2 2 1 1 5 4 4 3 4 2 3 7 1 8 0 11 9 9 3 1 5 3 5 8 6 8 7 3 1 3 3 1 3 1 2 1 7 0 10 8 6 2 4 7 8 8 7 2 1 1 3 1 3 3 3 1 1 9 0 11 1 6 9 1 3 4 6 9 1 6 8 3 2 2 2 3 1 3 1 1 2 5 1 4 3 3 5 3 6 1 5 0 11 2 9 9 5 8 1 3 4 6 4 5 3 3 1 3 3 1 5 0 10 7 4 2 9 8 5 9 1 9 5 2 1 3 2 1 1 8 0 9 7 2 9 1 3 2 9 9 4 1 3 1 3 1 2 2 3 1 4 2 2 1 3 5 3 1 5 5 5 4 3 4 1 5 0 8 3 7 4 1 3 6 2 7 2 1 3 2 2 1 9 0 7 1 1 5 1 5 8 9 2 1 3 1 1 2 2 1 3 1 6 0 9 5 8 7 9 8 9 1 5 9 3 1 2 1 3 1 3 1 3 3 3 6 1 6 0 8 4 1 5 6 2 6 6 9 2 2 1 1 3 3 1 6 0 11 7 1 6 6 4 4 6 9 5 1 5 1 2 3 1 1 1 1 9 0 8 8 1 4 3 8 2 1 1 2 1 2 3 1 3 2 3 2 3 1 2 5 2 4 3 4 1 5 0 8 1 3 7 7 5 1 8 6 3 1 1 3 1 1 7 0 7 2 2 1 1 6 3 1 2 1 1 2 2 1 3 1 6 0 7 1 9 8 7 9 8 2 2 2 2 3 1 1 3 2 3 2 3 5 1 5 0 9 4 6 1 5 1 8 4 9 5 1 1 1 2 2 1 9 0 6 6 1 7 8 4 8 1 3 1 3 1 1 3 3 3 1 7 0 7 6 1 3 9 6 4 7 2 1 2 1 2 2 1 3 4 3 4 2 3 7 1 5 0 8 6 1 1 7 5 1 9 9 2 1 2 1 1 1 9 0 6 2 4 7 1 1 5 3 3 2 1 2 1 1 3 2 1 7 0 6 6 6 1 1 4 4 3 2 1 3 1 1 3 3 5 5 2 1 5 3 3 5 1 5 4 4 3 5 1 9 0 11 7 8 9 5 3 3 5 3 7 3 1 2 2 2 3 2 1 2 1 1 1 8 0 6 6 7 3 3 1 8 2 1 1 3 1 1 2 3 1 8 0 7 1 6 8 1 4 7 2 1 3 3 3 3 2 1 1 2 1 4 2 5 3 5 1 7 0 10 5 2 4 8 1 7 7 8 1 1 2 1 2 3 2 1 2 1 5 0 8 8 3 6 1 6 4 9 9 2 3 2 1 1 1 7 0 10 5 2 1 1 4 6 5 1 4 2 2 1 3 1 2 1 2 4 4 1 1 4 3 6 1 7 0 9 4 5 4 7 8 8 4 1 2 1 3 1 3 3 3 1 1 8 0 6 8 5 5 9 1 2 3 1 2 1 1 3 1 1 1 5 0 10 2 8 5 1 6 2 1 7 4 1 2 1 1 1 1 4 4 2 5 1 3 3 6 1 7 0 8 2 5 4 5 1 4 1 4 1 3 3 3 2 1 1 1 5 0 9 8 9 7 1 8 4 4 7 8 1 2 3 1 1 1 8 0 10 3 3 2 7 5 3 1 4 1 8 1 1 3 1 1 1 1 3 3 1 4 4 1 4 6 6 2 2 4 5 3 1 5 1 1 5 6 5 8 4 7 2 diff --git a/day08/part1 b/day08/part1 new file mode 100755 index 0000000..ef22cfa --- /dev/null +++ b/day08/part1 @@ -0,0 +1,28 @@ +#!/usr/bin/env ruby + +def parse_tree(input, start) + num_children = input[start] + num_metadata = input[start + 1] + + next_index = start + 2 + sums = 0 + while num_children > 0 do + sum, endindex = parse_tree(input, next_index) + sums += sum + next_index = endindex + 1 + num_children -= 1 + end + + metadata = 0 + while num_metadata > 0 do + metadata += input[next_index] + next_index += 1 + num_metadata -= 1 + end + + return [ sums + metadata, next_index - 1] +end + +input = gets.chomp.split.map(&:to_i) + +puts parse_tree(input, 0)[0] diff --git a/day08/part2 b/day08/part2 new file mode 100755 index 0000000..94c2415 --- /dev/null +++ b/day08/part2 @@ -0,0 +1,36 @@ +#!/usr/bin/env ruby + +def parse_tree(input, start) + num_children = input[start] + num_metadata = input[start + 1] + + children = [] + next_index = start + 2 + while num_children > 0 do + sum, endindex = parse_tree(input, next_index) + children << sum + next_index = endindex + 1 + num_children -= 1 + end + + value = 0 + if children.empty? + while num_metadata > 0 do + value += input[next_index] + next_index += 1 + num_metadata -= 1 + end + else + while num_metadata > 0 do + i = input[next_index] + value += children[i - 1] if i <= children.length + next_index += 1 + num_metadata -= 1 + end + end + return [ value, next_index - 1 ] +end + +input = gets.chomp.split.map(&:to_i) + +puts parse_tree(input, 0)[0] -- cgit v1.2.1