summaryrefslogtreecommitdiff
path: root/2018
diff options
context:
space:
mode:
Diffstat (limited to '2018')
-rw-r--r--2018/Cargo.toml1
-rw-r--r--2018/input/8.txt1
-rw-r--r--2018/src/day8.rs66
-rw-r--r--2018/src/main.rs4
4 files changed, 71 insertions, 1 deletions
diff --git a/2018/Cargo.toml b/2018/Cargo.toml
index d071e14..484f482 100644
--- a/2018/Cargo.toml
+++ b/2018/Cargo.toml
@@ -2,6 +2,7 @@
name = "aoc-2018"
version = "0.1.0"
authors = ["tomsmeding <tom.smeding@gmail.com>"]
+edition = "2018"
[dependencies]
argparse = "0.2.2"
diff --git a/2018/input/8.txt b/2018/input/8.txt
new file mode 100644
index 0000000..de90adc
--- /dev/null
+++ b/2018/input/8.txt
@@ -0,0 +1 @@
+8 11 7 2 4 5 3 6 1 6 0 8 1 7 6 3 1 3 1 1 1 3 3 2 1 3 1 7 0 9 6 9 5 8 8 1 6 7 7 2 2 1 3 2 2 1 1 7 0 9 4 5 7 6 6 4 3 4 1 3 3 1 1 1 1 1 4 5 2 3 2 2 3 6 1 8 0 7 3 9 4 6 6 2 1 2 1 3 3 1 1 2 2 1 9 0 7 3 9 2 9 4 3 1 2 1 1 2 3 3 3 2 2 1 6 0 8 9 9 5 3 4 7 4 1 3 2 1 1 3 2 4 4 2 1 2 3 3 6 1 7 0 8 4 2 7 1 1 2 2 3 3 3 2 2 1 1 1 1 6 0 8 7 6 6 6 1 1 6 9 2 2 2 1 2 3 1 9 0 11 5 8 7 2 9 1 9 8 4 7 6 2 2 2 3 2 3 2 1 1 4 2 3 4 3 2 3 5 1 5 0 10 1 1 8 9 8 5 8 8 9 4 2 2 2 1 3 1 9 0 8 7 4 8 7 7 1 3 3 1 1 1 3 3 3 3 2 1 1 9 0 7 9 5 5 2 1 1 8 3 1 1 2 3 1 3 3 1 4 1 5 4 3 6 1 4 5 4 5 5 3 7 1 7 0 7 3 2 4 1 1 4 9 1 2 3 1 1 2 1 1 8 0 8 1 5 6 1 8 1 5 6 1 2 2 1 2 3 1 1 1 7 0 6 4 9 1 6 2 8 2 1 3 2 1 2 3 5 3 3 2 4 4 3 3 5 1 6 0 8 1 5 6 2 5 9 2 7 1 1 2 3 1 1 1 6 0 7 8 9 1 7 1 9 1 2 3 3 1 2 2 1 6 0 8 9 4 6 4 1 4 1 7 3 1 2 1 2 2 2 1 3 5 1 3 6 1 9 0 10 4 4 2 5 3 4 1 9 6 4 1 1 2 2 2 3 3 1 1 1 6 0 8 3 1 7 9 9 2 1 5 1 1 3 3 1 1 1 6 0 8 7 1 7 2 3 2 1 5 3 3 3 1 1 2 2 2 4 3 2 2 3 4 1 7 0 6 1 2 8 7 8 6 2 3 1 2 2 1 1 1 6 0 9 5 5 1 4 2 5 5 8 9 2 1 1 1 2 1 1 8 0 6 9 8 1 9 1 8 2 3 3 1 2 1 2 1 1 1 3 1 3 7 1 5 0 9 8 2 1 3 1 5 8 4 3 1 3 3 2 1 1 8 0 11 9 9 9 6 1 9 5 1 9 3 2 1 3 2 2 2 1 3 2 1 7 0 7 5 9 1 8 7 1 9 2 3 3 1 1 3 3 5 5 4 2 2 2 1 5 5 7 2 6 5 4 3 6 1 9 0 8 3 7 3 1 4 6 9 1 3 1 1 3 2 2 1 1 1 1 5 0 7 6 1 4 2 9 3 1 1 2 2 2 1 1 6 0 11 2 9 7 3 2 8 6 9 5 1 1 2 2 3 1 1 1 4 1 2 2 1 2 3 7 1 8 0 8 5 3 7 7 6 2 7 1 3 1 3 3 3 1 2 1 1 7 0 10 3 3 9 8 1 1 3 5 3 1 1 1 1 1 2 3 1 1 8 0 10 6 1 2 9 9 7 5 4 9 2 2 2 3 3 3 1 3 1 1 2 4 1 4 1 1 3 7 1 5 0 6 1 5 6 9 2 1 1 3 1 2 1 1 6 0 6 5 3 7 7 3 1 1 2 3 1 2 1 1 8 0 6 9 4 7 1 9 8 2 1 2 1 2 2 1 2 4 5 2 4 3 3 1 3 7 1 6 0 8 2 5 1 2 4 1 1 5 1 3 1 3 2 2 1 6 0 8 6 4 9 8 8 4 1 1 2 1 3 1 1 3 1 6 0 8 9 7 9 9 3 3 3 1 2 2 1 3 3 3 3 1 1 5 1 1 4 3 5 1 6 0 8 8 8 4 1 5 8 1 3 2 2 1 3 1 1 1 8 0 6 2 3 1 4 3 8 3 3 3 2 1 2 3 3 1 6 0 10 3 7 9 1 5 6 4 4 8 5 3 2 1 2 1 3 4 4 1 1 2 7 6 6 2 4 5 3 6 1 8 0 9 9 9 7 7 4 2 1 5 9 1 3 1 3 3 1 1 3 1 6 0 10 2 8 7 2 1 1 9 6 5 5 3 1 2 2 1 1 1 7 0 7 4 8 1 2 9 5 1 3 1 2 1 1 2 2 4 2 4 2 5 1 3 5 1 7 0 6 7 8 4 1 1 7 2 1 3 2 3 2 2 1 6 0 6 4 4 1 5 2 7 2 2 1 3 3 3 1 7 0 11 9 9 4 8 1 4 7 1 9 4 1 1 1 3 2 1 1 1 2 1 2 4 4 3 6 1 5 0 9 5 7 5 1 2 2 8 7 7 3 3 1 2 2 1 9 0 11 6 4 2 1 1 3 9 2 4 1 7 1 1 3 3 1 2 2 1 3 1 7 0 7 4 2 1 2 9 1 2 2 1 3 1 3 3 1 4 3 2 2 3 3 3 7 1 6 0 7 6 9 3 1 3 6 1 3 1 3 1 1 2 1 8 0 6 9 2 2 1 4 1 1 3 1 3 1 2 2 1 1 9 0 6 8 9 1 6 1 1 2 1 3 3 2 2 1 3 2 4 1 4 2 3 4 3 1 1 3 3 4 5 5 3 7 1 9 0 6 9 6 8 8 2 1 2 2 1 1 1 2 3 1 2 1 5 0 11 9 3 9 1 1 4 2 8 4 3 2 2 1 2 2 1 1 5 0 6 5 1 8 3 3 4 1 1 1 2 1 2 1 1 4 1 1 1 3 7 1 9 0 10 8 9 1 8 8 6 3 9 2 8 1 1 2 3 1 3 2 1 3 1 9 0 11 7 1 3 4 1 4 2 4 3 4 3 1 2 2 1 1 2 2 1 3 1 5 0 7 4 6 7 1 8 5 8 1 1 1 1 3 5 1 1 1 5 5 3 3 7 1 6 0 6 1 2 4 7 7 5 1 1 2 1 3 2 1 5 0 6 2 5 1 9 1 8 1 3 2 3 3 1 7 0 11 4 4 3 4 1 3 6 9 8 7 1 2 3 3 1 2 3 2 4 2 3 3 1 3 5 3 6 1 8 0 11 1 5 9 1 3 9 7 8 5 1 5 1 1 3 2 1 2 3 2 1 6 0 11 6 3 1 6 4 6 2 6 1 1 6 1 2 1 1 1 2 1 6 0 10 4 5 2 1 1 5 5 5 8 1 3 1 1 1 2 2 1 1 4 1 1 4 3 4 1 6 0 6 5 1 2 4 1 1 2 1 1 1 3 1 1 5 0 8 9 1 4 8 1 6 6 8 1 1 3 3 3 1 9 0 8 1 8 2 8 7 8 5 7 3 3 1 2 1 2 1 2 1 3 3 1 1 7 1 3 2 4 5 3 3 4 1 5 0 9 6 8 7 1 9 7 6 4 1 2 1 3 2 3 1 8 0 11 5 1 6 1 9 6 8 3 2 6 5 2 3 1 1 1 3 2 1 1 7 0 8 3 1 1 5 9 2 4 9 2 1 1 2 3 2 2 3 2 1 2 3 4 1 7 0 6 9 9 1 9 7 3 3 2 1 1 3 2 3 1 7 0 11 5 3 3 4 8 9 9 3 8 7 1 1 2 1 1 1 3 2 1 8 0 8 6 5 3 1 7 7 8 2 2 3 3 1 1 2 3 1 3 1 5 1 3 4 1 8 0 10 1 2 7 4 6 5 1 6 6 1 1 2 1 3 3 3 2 1 1 6 0 11 4 8 5 4 6 1 5 9 6 7 6 2 1 1 1 3 3 1 8 0 7 1 8 5 5 3 9 9 1 1 1 2 2 1 1 1 3 2 4 2 3 7 1 5 0 10 6 5 6 1 1 2 2 9 8 5 3 2 1 2 2 1 8 0 8 2 6 4 6 1 9 2 5 1 1 1 3 2 3 3 2 1 9 0 7 6 1 8 8 9 7 6 1 1 3 1 2 2 2 3 2 1 4 1 1 3 4 1 3 4 1 9 0 10 8 7 6 1 1 8 3 3 6 5 1 2 2 1 1 3 3 1 1 1 8 0 11 7 3 6 1 1 1 6 2 2 6 1 1 2 3 1 2 1 2 3 1 8 0 6 7 1 2 3 1 3 2 1 1 1 2 1 3 1 2 5 2 4 3 3 5 4 3 3 6 1 5 0 11 7 5 3 5 8 8 3 1 8 9 1 1 1 3 1 3 1 5 0 8 8 6 3 1 1 7 9 9 3 1 2 1 2 1 9 0 9 7 4 2 1 6 6 5 5 8 1 2 2 2 3 1 2 1 2 1 2 5 4 1 3 3 5 1 8 0 7 4 5 6 4 9 1 9 1 2 1 3 2 3 1 1 1 8 0 9 2 9 4 1 3 9 8 7 9 1 2 1 2 1 3 2 2 1 7 0 10 9 2 6 8 6 3 1 1 7 4 1 3 2 1 2 1 3 5 1 3 2 4 3 6 1 6 0 7 8 1 6 1 3 7 2 1 1 1 3 2 3 1 7 0 7 7 2 1 2 3 6 2 2 3 1 2 1 3 2 1 9 0 11 1 2 6 5 8 8 7 1 9 2 2 3 1 2 2 2 1 2 3 2 3 4 4 1 4 3 3 7 1 5 0 8 8 1 6 5 4 8 5 8 1 2 3 1 1 1 6 0 10 1 3 1 8 4 8 3 2 5 6 1 2 1 1 2 2 1 6 0 11 6 9 4 8 6 4 1 6 5 3 3 1 1 3 1 3 1 5 3 3 4 2 3 1 4 3 4 7 3 7 2 4 5 3 5 1 8 0 6 9 7 1 8 1 8 2 2 1 3 1 3 1 1 1 5 0 10 1 1 6 4 9 6 2 9 6 9 2 2 2 1 2 1 5 0 10 5 1 2 6 6 9 1 8 2 4 2 1 2 3 1 3 2 3 2 3 3 4 1 8 0 7 7 2 1 7 5 1 8 2 1 2 1 1 3 2 3 1 7 0 8 1 7 4 1 8 6 2 8 1 1 1 1 2 1 3 1 6 0 11 3 3 5 1 6 9 9 8 6 2 1 1 1 2 2 2 1 3 3 4 1 3 4 1 7 0 6 4 2 2 2 3 1 2 2 1 1 1 1 2 1 8 0 7 6 1 5 7 1 1 5 3 3 3 1 3 3 3 3 1 6 0 10 8 7 7 8 9 5 1 6 1 8 1 3 1 3 1 1 3 5 5 1 3 4 1 6 0 8 4 5 5 1 1 5 1 9 2 1 3 3 1 1 1 5 0 7 5 1 3 1 4 5 1 1 2 3 3 1 1 7 0 6 6 6 3 1 2 3 2 1 2 1 3 1 3 4 2 2 2 5 6 3 3 5 5 4 3 7 1 9 0 10 1 8 3 7 1 6 4 9 7 7 3 2 1 2 3 2 3 3 2 1 6 0 10 4 7 7 2 1 2 8 6 4 6 1 1 2 1 2 2 1 5 0 10 9 2 4 1 5 4 9 6 1 7 3 1 2 2 3 3 3 4 5 2 5 2 3 5 1 5 0 6 2 8 8 1 7 4 2 2 1 1 3 1 6 0 6 2 8 6 4 1 2 1 2 1 1 3 1 1 9 0 6 1 4 9 1 7 3 1 1 2 2 3 3 2 1 1 2 1 2 5 3 3 6 1 9 0 11 5 1 1 1 1 4 2 3 5 1 7 1 1 1 3 1 2 3 1 1 1 7 0 9 4 1 7 7 2 2 6 7 5 3 2 2 3 3 1 2 1 5 0 6 2 2 1 9 8 1 1 3 3 1 1 1 1 3 3 3 3 3 6 1 9 0 9 5 5 4 1 9 7 6 6 1 1 3 1 2 3 2 3 1 3 1 5 0 8 1 7 7 6 4 2 6 1 2 2 1 1 2 1 8 0 6 1 2 9 3 4 8 1 2 2 1 2 1 3 1 4 3 4 4 5 3 3 7 1 9 0 9 6 8 4 6 9 5 7 1 4 2 3 1 3 1 1 3 2 1 1 7 0 8 7 5 9 4 8 5 1 8 2 1 3 3 2 1 2 1 6 0 10 4 6 2 2 4 1 3 7 4 8 1 1 3 2 3 3 5 3 2 1 5 3 2 7 2 6 3 4 3 3 4 1 8 0 9 2 6 9 4 6 2 5 1 1 1 1 3 2 1 1 2 2 1 7 0 6 2 1 1 3 7 7 1 2 3 1 3 2 2 1 9 0 10 5 6 6 1 6 2 5 3 7 7 1 1 2 2 3 1 3 1 2 3 5 1 2 3 4 1 9 0 8 2 6 7 1 4 5 5 2 3 1 1 1 1 3 1 2 2 1 6 0 10 1 2 6 3 6 3 1 5 1 5 1 2 1 1 3 3 1 6 0 11 8 6 9 6 8 8 4 7 1 3 2 2 3 2 3 1 1 3 3 1 1 3 7 1 8 0 7 4 3 3 1 9 4 1 1 2 1 1 2 3 1 1 1 8 0 11 6 9 1 7 5 3 7 1 4 7 4 1 1 2 3 2 1 2 3 1 8 0 10 1 8 7 6 6 9 1 2 3 4 1 1 2 1 1 3 2 2 5 3 3 4 2 2 5 3 6 1 9 0 10 1 1 4 2 8 7 9 4 5 4 3 1 3 1 1 3 2 1 2 1 7 0 11 9 1 5 3 7 9 3 7 7 1 4 1 3 2 3 2 2 1 1 9 0 10 1 5 9 9 2 6 4 1 8 1 3 2 1 3 1 2 3 2 1 5 5 1 2 4 5 5 3 2 5 5 3 4 1 5 0 10 9 7 3 2 4 2 4 1 5 1 1 3 1 3 2 1 6 0 10 7 4 1 6 4 6 8 9 4 3 2 1 1 1 3 3 1 7 0 7 1 6 8 1 8 4 8 1 1 3 3 1 1 1 1 1 4 3 3 5 1 8 0 9 2 5 3 2 1 6 2 5 3 3 1 3 3 2 1 1 2 1 8 0 11 4 7 1 2 6 6 8 2 8 4 3 3 2 1 3 1 1 2 1 1 6 0 9 4 2 2 1 4 8 7 2 1 1 2 2 1 2 2 2 2 5 4 1 3 4 1 8 0 7 3 2 5 4 1 1 6 3 3 3 2 2 3 1 1 1 7 0 10 4 5 1 7 8 1 3 6 9 5 3 1 3 1 3 3 2 1 7 0 10 1 5 2 4 8 5 8 1 4 6 1 2 1 2 1 2 2 2 2 4 4 3 7 1 5 0 6 6 1 8 8 8 7 1 3 2 2 1 1 8 0 9 6 5 1 6 1 3 1 2 4 3 2 1 1 1 3 1 1 1 6 0 8 8 5 1 2 5 5 1 5 3 1 1 1 1 2 1 2 4 3 2 2 5 3 6 1 9 0 9 2 1 2 5 7 1 3 3 3 1 2 2 1 2 2 1 1 1 1 8 0 10 9 8 3 5 9 6 1 8 6 5 3 1 3 3 1 1 1 1 1 8 0 6 2 2 7 1 8 7 3 3 3 1 3 1 3 2 4 5 2 5 2 1 6 3 7 3 7 5 3 3 7 1 9 0 10 6 1 4 8 5 7 9 1 2 9 1 3 3 3 2 3 1 1 2 1 8 0 8 4 2 3 4 1 9 9 3 1 3 1 2 1 1 1 3 1 9 0 6 8 8 9 7 1 9 3 1 2 1 3 2 1 3 2 2 5 2 1 5 2 5 3 5 1 9 0 11 6 1 2 1 1 1 8 7 5 4 4 2 2 1 3 2 3 2 3 2 1 5 0 11 5 6 8 4 3 1 6 3 1 5 4 1 3 3 1 2 1 7 0 8 2 4 5 2 3 3 1 6 1 3 3 1 3 2 3 4 3 4 2 1 3 7 1 8 0 10 6 1 1 8 9 8 2 7 2 5 1 1 3 1 2 1 1 1 1 8 0 9 1 9 3 6 7 1 2 1 9 2 1 2 1 3 3 3 2 1 5 0 11 8 2 9 6 1 1 2 6 7 5 6 2 1 1 2 1 1 3 2 2 2 4 1 3 4 1 7 0 8 1 4 4 9 7 7 4 2 2 1 1 3 3 2 1 1 5 0 11 9 1 5 1 6 8 5 5 1 7 7 1 3 3 2 3 1 8 0 7 6 4 6 7 1 3 1 1 2 2 2 1 2 1 1 4 5 5 2 3 4 1 6 0 7 7 1 7 4 6 9 1 3 1 3 1 3 2 1 9 0 10 7 5 7 6 1 2 3 1 9 3 3 1 1 2 1 3 3 3 2 1 7 0 7 2 1 2 9 7 3 1 1 1 2 2 2 3 3 1 3 1 4 4 4 5 5 5 3 7 1 7 0 8 9 3 1 9 9 4 7 1 1 3 3 1 3 3 2 1 5 0 8 1 3 8 6 4 9 7 1 3 3 3 3 1 1 6 0 8 5 1 7 7 3 1 5 6 2 1 1 2 1 3 3 2 3 5 1 2 2 3 7 1 5 0 11 4 6 1 7 3 1 8 8 4 9 1 2 1 2 3 1 1 6 0 7 8 8 3 1 5 2 9 3 1 2 3 3 1 1 9 0 10 7 5 1 5 7 4 1 2 9 2 1 2 3 1 1 3 2 1 3 5 4 3 4 2 2 1 3 6 1 6 0 8 6 7 3 4 5 2 1 5 3 3 2 2 1 3 1 5 0 6 1 7 5 9 2 3 2 3 2 3 1 1 5 0 10 1 3 1 5 3 6 1 6 4 4 3 1 2 2 2 1 2 5 2 3 3 3 5 1 5 0 10 7 1 2 2 6 8 5 4 7 3 2 2 1 1 3 1 5 0 11 1 1 3 3 1 3 1 3 7 3 5 1 2 3 2 1 1 6 0 9 1 1 3 1 2 8 3 5 7 2 1 3 1 2 2 3 3 3 2 4 3 4 1 8 0 9 1 2 8 4 5 5 5 7 1 2 3 1 1 1 2 2 2 1 6 0 8 6 9 6 1 5 1 8 1 1 2 3 2 1 1 1 8 0 8 2 5 1 1 5 2 2 3 1 3 1 2 1 3 2 1 1 4 4 4 2 1 3 6 7 5 4 3 7 1 8 0 11 4 1 1 5 3 4 2 8 6 5 1 1 1 3 3 3 1 2 1 1 8 0 6 3 5 4 8 3 1 2 2 3 1 1 2 2 3 1 8 0 11 8 4 2 2 4 8 1 5 1 4 3 1 1 3 1 1 2 2 3 4 4 1 4 2 1 4 3 6 1 5 0 10 1 8 2 3 3 5 3 7 1 5 1 1 2 3 3 1 9 0 7 7 1 3 7 4 4 4 2 1 2 3 2 2 1 2 3 1 5 0 11 1 7 2 6 4 1 5 1 5 2 2 1 1 2 1 2 2 2 1 5 3 1 3 4 1 9 0 8 7 6 5 1 8 8 4 7 1 2 1 1 3 1 2 3 1 1 6 0 10 7 9 6 8 9 5 6 6 1 1 2 1 3 2 3 3 1 7 0 9 4 1 3 2 2 7 9 6 3 1 2 2 1 1 1 2 5 3 3 2 3 6 1 5 0 11 8 1 9 4 1 3 6 6 7 7 2 1 1 2 1 3 1 5 0 7 3 9 1 1 1 5 9 1 3 1 1 3 1 6 0 7 9 9 2 9 1 1 7 2 1 3 1 1 2 5 1 5 2 2 3 3 4 1 5 0 10 4 7 8 4 1 4 7 8 5 7 1 1 2 2 2 1 5 0 11 3 8 6 7 1 9 1 8 4 9 1 2 3 1 1 2 1 7 0 6 1 8 3 1 7 8 2 1 1 1 3 1 3 3 2 4 3 3 6 1 2 6 6 6 2 4 4 3 4 1 5 0 7 6 8 6 2 1 3 5 2 1 1 3 3 1 6 0 10 6 1 7 1 7 9 9 3 1 7 1 2 2 1 2 3 1 5 0 8 1 8 3 5 4 7 5 1 1 1 1 1 1 1 2 1 2 3 5 1 8 0 9 3 9 1 4 2 6 2 9 5 2 2 3 1 1 1 2 1 1 5 0 7 7 5 1 8 8 1 4 3 1 1 3 1 1 7 0 6 5 1 4 6 8 9 3 2 2 3 1 2 2 5 4 1 3 1 3 4 1 7 0 9 2 1 7 8 6 6 5 3 9 3 1 1 1 1 2 3 1 7 0 6 1 6 1 8 5 4 1 2 1 1 1 2 1 1 7 0 7 4 8 7 4 1 2 1 1 1 1 2 3 3 3 5 5 3 3 3 6 1 8 0 7 5 1 5 1 4 7 3 2 1 2 3 1 3 1 2 1 9 0 6 9 9 7 5 1 8 1 2 2 3 3 3 3 2 1 1 6 0 8 1 6 5 5 3 6 1 2 1 3 2 2 3 3 5 4 1 3 4 3 3 4 3 1 4 5 3 5 1 6 0 8 7 5 3 4 7 1 7 2 1 3 2 2 1 3 1 8 0 10 2 7 3 2 9 1 7 3 4 9 3 3 2 1 1 2 3 1 1 8 0 11 7 5 4 1 8 8 8 9 2 9 4 2 1 1 3 3 1 1 1 1 2 2 3 1 3 5 1 6 0 6 1 5 6 2 2 4 1 2 2 3 1 1 1 7 0 10 9 7 5 8 6 2 8 2 1 5 3 1 2 2 3 3 3 1 7 0 8 3 9 1 1 6 8 7 9 2 2 1 1 1 3 3 3 5 2 5 3 3 5 1 9 0 8 2 3 9 7 8 5 1 7 1 1 3 1 3 2 1 2 2 1 9 0 11 9 6 5 1 2 7 9 6 5 2 2 3 1 1 1 3 1 2 2 1 1 5 0 10 4 8 9 1 1 7 2 2 8 1 3 2 3 1 1 1 2 1 5 4 3 6 1 5 0 7 7 7 1 2 6 6 2 3 1 1 2 1 1 6 0 6 1 6 7 5 2 3 2 1 1 1 1 3 1 9 0 6 2 4 1 8 1 7 1 3 3 3 1 1 1 2 1 1 2 2 4 4 5 1 3 6 6 1 5 3 3 4 1 9 0 10 3 4 9 3 4 1 1 2 4 9 3 2 1 1 3 2 2 2 2 1 5 0 9 1 1 2 1 4 9 3 2 6 3 1 2 3 1 1 9 0 10 3 9 5 8 8 8 6 1 7 5 2 3 3 1 2 1 3 1 1 2 1 1 4 3 6 1 9 0 7 8 3 1 5 2 6 1 3 1 3 3 2 1 2 1 1 1 9 0 7 1 5 5 9 8 6 4 2 1 2 1 2 3 2 3 2 1 7 0 9 1 2 9 1 5 6 2 8 2 2 2 3 1 1 1 2 2 1 2 3 2 3 3 7 1 5 0 11 6 5 1 7 2 4 4 3 5 9 7 3 2 3 1 3 1 6 0 9 6 6 5 7 9 1 3 5 2 1 3 3 1 2 1 1 5 0 6 7 1 9 6 9 2 2 2 1 1 1 5 3 2 1 1 5 2 3 6 1 9 0 9 5 2 2 1 4 6 2 4 9 3 3 1 1 1 2 3 3 3 1 9 0 7 1 9 2 9 7 1 1 1 1 2 1 1 3 2 1 1 1 5 0 8 6 9 5 2 1 9 1 2 2 3 2 1 1 2 1 4 3 3 2 3 4 1 8 0 7 1 2 9 2 8 8 8 3 2 1 2 1 2 3 2 1 9 0 11 6 1 9 5 2 6 9 7 1 2 7 3 1 3 2 2 3 1 1 2 1 6 0 6 2 2 1 4 8 9 1 1 2 3 1 2 3 3 1 5 2 5 4 4 4 3 4 1 9 0 8 5 9 5 3 3 1 5 9 1 2 1 2 2 2 2 2 1 1 7 0 10 2 9 8 7 6 2 4 1 6 8 2 3 2 1 3 1 1 1 8 0 11 5 4 2 2 8 7 4 3 1 2 1 1 3 3 3 1 3 1 1 1 2 3 4 3 6 1 7 0 9 7 4 4 8 8 3 1 1 7 2 2 3 1 1 1 1 1 6 0 9 8 7 3 8 1 1 7 1 5 2 2 2 3 3 1 1 7 0 6 4 1 9 9 4 6 1 3 1 3 1 2 1 3 4 1 4 3 2 3 4 1 5 0 6 2 1 3 7 2 3 3 1 1 1 1 1 5 0 8 6 6 7 9 2 9 4 1 1 2 2 1 1 1 6 0 7 7 4 6 8 6 1 9 3 1 1 3 2 2 1 1 3 2 3 6 1 8 0 9 2 2 6 6 9 1 7 9 2 2 2 3 3 3 1 3 1 1 5 0 8 5 6 5 1 5 8 8 8 2 3 3 1 1 1 9 0 10 1 8 5 2 2 5 9 2 8 9 1 1 2 3 1 1 3 2 1 4 2 4 5 3 1 2 4 4 2 4 4 3 5 1 8 0 10 8 3 9 3 1 6 5 1 6 7 1 3 2 1 1 2 1 3 1 7 0 7 9 9 8 8 1 4 5 1 2 3 2 1 1 2 1 5 0 11 6 8 1 8 5 9 9 2 2 6 3 2 3 1 2 1 1 5 1 1 1 3 7 1 6 0 9 9 1 2 1 1 2 7 8 3 2 1 3 2 3 1 1 6 0 7 8 4 2 1 1 9 1 2 2 1 2 3 1 1 5 0 7 7 1 1 1 4 6 6 1 3 2 1 2 5 4 5 2 5 1 5 3 7 1 8 0 11 5 8 5 4 1 2 3 5 3 6 4 3 1 2 1 1 1 2 2 1 5 0 11 6 1 9 6 7 4 8 6 2 6 9 3 1 1 3 3 1 6 0 8 7 1 6 3 3 9 9 1 1 3 1 2 2 1 3 5 2 5 1 4 5 3 4 1 5 0 6 3 4 2 6 4 1 3 1 1 3 1 1 5 0 6 1 6 1 7 7 1 3 2 1 3 2 1 6 0 8 9 6 1 2 7 1 1 9 2 2 2 3 3 1 1 5 5 1 3 2 6 2 5 5 3 6 1 8 0 7 1 3 8 7 1 6 1 1 1 3 1 2 2 2 2 1 8 0 10 7 8 1 4 6 9 9 9 1 4 3 3 3 3 2 2 1 3 1 8 0 8 4 9 9 1 7 2 1 2 1 2 3 1 1 2 2 1 1 3 5 4 1 2 3 5 1 9 0 7 1 4 1 9 3 2 4 3 3 3 3 3 2 1 1 1 1 9 0 11 5 4 8 2 6 2 1 4 8 9 1 2 3 1 3 3 1 2 3 1 1 7 0 8 6 2 4 6 8 1 8 6 2 2 1 3 3 1 1 3 5 5 2 3 3 5 1 5 0 6 1 2 1 4 1 5 1 1 1 1 3 1 9 0 6 9 1 4 7 1 7 3 3 3 2 1 3 2 3 1 1 8 0 7 2 1 1 2 1 9 6 1 2 2 3 1 1 1 1 1 4 3 1 2 3 7 1 5 0 11 6 1 2 5 5 7 4 3 1 3 6 2 2 3 1 3 1 6 0 9 1 8 5 7 1 6 8 9 1 1 1 1 2 2 3 1 9 0 8 9 6 9 5 2 8 1 7 1 1 3 1 3 3 2 2 1 4 3 1 5 3 3 1 3 6 1 6 0 11 1 9 5 7 8 6 7 7 6 6 4 1 1 3 1 1 2 1 7 0 7 6 7 9 1 4 7 1 3 3 1 3 1 3 2 1 8 0 9 9 1 9 1 8 3 5 5 2 3 1 3 2 1 1 3 2 3 2 3 2 5 2 4 2 6 4 6 8 6 6 3 5 3 3 7 1 8 0 10 3 2 8 5 1 1 9 4 4 3 3 1 2 2 2 1 2 1 1 5 0 8 6 1 9 4 9 3 1 9 1 3 3 1 1 1 8 0 6 7 7 9 1 3 7 1 3 1 3 1 3 2 2 2 5 2 1 2 5 2 3 7 1 7 0 8 9 1 3 3 3 3 4 5 1 2 1 3 2 3 1 1 5 0 8 3 1 5 1 4 6 5 4 3 2 1 1 3 1 6 0 9 1 3 8 3 6 3 2 2 1 3 1 2 1 3 2 5 4 3 3 3 2 1 3 7 1 7 0 9 8 4 1 2 6 6 1 1 1 3 3 1 3 1 1 1 1 8 0 6 4 8 1 1 7 2 2 1 3 2 1 1 1 1 1 6 0 6 1 3 3 9 7 5 3 1 1 2 1 1 3 3 2 3 5 2 1 3 4 1 8 0 9 4 8 1 6 3 5 1 2 4 3 1 1 2 2 2 1 2 1 9 0 10 9 4 2 1 2 4 5 3 4 1 1 3 3 2 2 1 3 1 1 1 8 0 6 4 7 5 2 6 1 3 1 3 2 1 3 2 1 5 5 2 2 3 7 1 8 0 8 5 4 1 7 1 3 6 6 3 2 1 1 1 2 3 3 1 5 0 10 4 6 5 5 5 1 4 8 4 6 3 1 2 1 2 1 6 0 6 1 8 7 8 1 9 2 2 3 1 1 1 2 3 4 3 4 3 2 2 1 4 5 5 3 7 1 9 0 8 6 1 7 6 9 6 6 1 3 1 3 3 3 2 1 2 1 1 8 0 10 1 2 7 7 1 7 7 1 8 7 1 2 1 3 1 3 1 1 1 6 0 10 3 8 2 7 9 5 9 1 2 8 3 1 3 3 1 2 5 1 3 1 2 1 5 3 7 1 9 0 6 1 7 1 3 4 8 1 1 1 3 3 1 2 3 1 1 7 0 7 9 6 3 5 7 6 1 2 2 1 2 1 2 1 1 9 0 7 1 4 6 3 9 1 3 2 3 2 3 2 1 1 1 1 2 3 3 5 4 5 4 3 5 1 6 0 6 5 7 1 1 8 2 1 1 1 2 2 3 1 6 0 8 3 1 8 3 7 3 6 4 3 1 3 3 1 1 1 5 0 9 2 9 1 8 1 5 7 9 8 1 1 3 3 1 2 2 1 4 4 3 6 1 5 0 6 8 1 4 6 5 2 1 3 1 2 1 1 7 0 11 5 4 8 1 9 2 9 2 7 6 3 3 1 2 1 2 2 3 1 8 0 6 1 5 4 5 4 4 1 3 2 3 1 1 1 1 5 3 3 4 1 3 3 7 1 8 0 7 5 1 5 8 7 1 6 3 2 1 3 2 3 1 3 1 5 0 6 9 6 1 6 7 9 2 1 1 2 1 1 6 0 7 3 8 2 4 1 7 4 1 2 1 1 2 2 4 2 3 2 2 4 2 4 6 3 3 5 5 5 3 7 1 8 0 10 6 2 2 8 1 5 2 9 9 2 1 1 3 2 3 1 2 3 1 7 0 7 6 1 1 8 9 9 2 1 3 2 2 3 1 1 1 8 0 10 6 6 7 1 8 1 7 3 4 7 2 2 2 3 2 1 2 1 3 2 2 2 2 5 1 3 7 1 6 0 10 1 4 7 1 8 5 2 2 4 9 3 1 1 1 1 2 1 5 0 8 6 3 2 2 9 9 5 1 1 1 2 2 1 1 7 0 6 1 3 8 4 4 6 1 2 1 2 1 3 3 1 2 3 4 3 4 2 3 6 1 5 0 11 8 9 1 4 8 1 5 2 7 2 6 1 1 1 3 3 1 7 0 11 6 9 5 5 8 1 1 1 6 1 5 1 2 1 2 2 3 2 1 6 0 9 5 3 1 5 1 8 6 6 1 2 2 2 1 2 1 2 1 3 3 2 3 3 7 1 5 0 7 1 3 9 2 7 3 6 2 3 1 1 1 1 5 0 11 9 2 1 3 7 5 3 1 7 8 5 3 1 3 1 1 1 9 0 6 4 9 5 6 1 4 3 1 2 2 3 1 1 3 2 4 2 3 2 4 1 5 3 5 1 5 0 8 4 1 5 7 5 8 1 7 2 1 1 3 3 1 6 0 7 7 2 6 1 4 1 7 3 1 1 2 3 3 1 8 0 7 3 2 9 1 1 9 8 2 1 3 3 3 3 2 2 1 3 3 1 5 3 4 7 5 3 4 3 3 6 1 7 0 7 1 5 8 1 9 8 9 3 3 2 1 3 1 1 1 6 0 8 1 5 9 4 5 1 1 4 3 2 1 2 1 2 1 5 0 9 1 2 5 4 1 1 3 5 7 1 1 3 2 1 4 1 5 4 3 5 3 7 1 9 0 8 1 6 6 2 1 3 6 2 1 3 3 2 1 2 1 3 1 1 5 0 11 6 9 2 1 1 3 9 5 5 3 3 2 1 1 1 1 1 6 0 7 7 8 1 3 2 8 4 3 1 3 3 2 2 4 2 2 1 5 1 3 3 5 1 6 0 6 1 5 3 4 9 4 1 3 3 1 1 1 1 6 0 7 3 1 1 7 6 1 4 3 1 2 1 3 2 1 6 0 8 3 1 7 9 5 8 1 3 2 1 2 1 3 1 2 1 4 3 4 3 4 1 6 0 6 3 1 5 2 1 2 2 1 2 2 3 1 1 9 0 6 6 7 3 6 1 8 1 2 2 2 3 2 2 2 1 1 9 0 9 4 6 4 3 2 3 1 7 2 2 3 2 3 2 1 1 1 3 2 3 1 5 3 3 2 5 3 3 5 1 6 0 11 3 6 8 1 7 6 9 7 1 1 3 2 1 2 1 2 1 1 9 0 9 5 7 1 1 1 2 8 7 4 2 3 3 2 1 3 1 1 1 1 6 0 10 1 3 9 4 2 6 1 9 2 9 1 3 2 3 1 2 2 1 3 1 2 3 4 1 8 0 10 7 1 9 7 7 9 2 9 5 6 1 2 2 1 2 2 3 1 1 9 0 7 1 9 6 4 1 2 5 3 1 1 1 3 3 1 1 1 1 9 0 11 2 1 5 1 9 9 2 5 4 8 2 3 3 2 2 1 2 3 3 3 1 4 4 1 3 5 1 7 0 10 1 7 4 8 2 7 9 9 1 5 2 1 2 1 1 1 2 1 9 0 11 1 1 4 2 1 8 2 1 4 9 9 2 2 2 3 3 1 2 3 3 1 5 0 7 8 1 5 5 6 6 1 3 2 2 1 1 5 1 3 3 5 3 6 1 7 0 9 4 8 5 7 3 7 8 1 4 1 3 1 2 3 2 2 1 6 0 9 9 7 9 8 9 3 1 7 1 1 2 3 2 1 1 1 8 0 6 8 5 9 1 9 1 1 2 3 2 1 1 2 2 3 4 5 1 3 3 3 7 1 9 0 6 1 5 5 7 1 2 1 3 2 2 1 1 3 3 1 1 8 0 8 3 4 1 9 3 8 5 5 2 1 2 3 3 1 1 2 1 8 0 10 4 3 6 1 8 3 2 2 6 9 2 2 1 3 1 1 1 1 5 4 3 1 3 3 2 7 3 3 4 3 3 4 1 7 0 7 1 2 2 6 3 2 5 3 2 3 1 3 1 2 1 9 0 9 1 8 2 2 8 6 4 3 7 1 1 1 2 1 3 3 3 3 1 5 0 11 4 1 9 6 5 1 5 1 6 3 9 1 1 3 2 3 2 1 1 1 3 6 1 7 0 6 1 3 6 7 5 9 3 1 1 2 1 3 1 1 8 0 6 1 9 6 6 8 1 3 3 3 1 3 1 1 3 1 9 0 9 2 2 1 1 5 6 1 4 2 1 1 3 2 1 1 3 3 1 1 4 4 3 3 1 3 7 1 7 0 8 2 2 2 8 4 6 1 5 1 3 2 2 3 1 2 1 6 0 8 9 6 9 6 2 7 8 1 1 1 1 1 3 1 1 9 0 7 1 9 4 8 6 1 8 3 3 3 2 3 2 2 1 2 3 2 1 1 3 1 3 3 7 1 8 0 11 6 9 1 7 9 9 8 7 6 7 1 1 2 2 1 1 2 3 3 1 6 0 9 5 6 1 1 1 8 1 1 4 1 3 2 2 2 1 1 5 0 6 1 8 1 7 3 7 1 1 1 1 3 2 2 2 2 1 2 4 3 6 3 8 8 1 7 3 5 4 3 5 1 8 0 11 7 4 4 9 1 8 2 1 1 1 1 1 2 1 1 3 3 1 1 1 8 0 9 1 9 1 2 9 7 4 7 5 1 3 1 2 3 2 2 3 1 5 0 10 9 5 2 7 8 1 1 1 8 4 1 1 2 1 2 3 1 2 3 2 3 4 1 8 0 10 1 5 2 5 9 5 2 3 4 5 1 1 1 1 2 1 3 1 1 5 0 9 1 9 4 6 6 9 5 1 1 2 1 1 3 2 1 6 0 8 4 6 2 2 9 1 6 2 1 3 2 2 2 3 1 1 2 3 3 7 1 6 0 7 4 5 6 1 2 2 1 2 1 3 2 2 2 1 6 0 10 6 8 1 6 3 3 9 1 3 5 1 2 2 1 1 2 1 5 0 6 3 1 2 2 7 5 2 1 3 1 1 3 4 2 2 3 4 1 3 7 1 7 0 8 5 6 8 1 5 7 8 5 3 2 1 1 1 2 3 1 7 0 7 1 4 6 1 9 8 8 3 1 1 1 3 1 1 1 9 0 7 7 4 7 5 1 3 5 1 2 1 3 3 2 3 3 2 1 4 2 5 2 2 2 3 6 1 7 0 8 1 6 3 9 6 6 2 1 1 3 2 1 3 1 2 1 9 0 10 1 4 2 7 9 3 5 7 2 7 1 3 1 1 1 2 3 3 3 1 7 0 6 3 1 9 1 8 5 2 3 1 1 1 2 3 3 2 4 2 3 5 1 2 5 2 5 5 3 7 1 6 0 7 4 8 1 4 2 8 3 3 2 2 1 2 2 1 9 0 9 8 4 7 3 1 5 6 1 4 3 2 1 2 1 2 2 3 1 1 8 0 9 5 9 6 5 4 9 1 7 4 3 2 3 1 2 1 1 1 4 4 1 1 1 3 4 3 7 1 9 0 11 3 6 6 1 9 4 1 4 7 3 5 1 3 2 2 2 3 1 2 2 1 7 0 7 1 2 3 1 1 3 5 2 1 1 2 1 3 2 1 8 0 7 1 2 1 5 4 3 9 3 2 2 3 3 1 1 2 2 1 3 3 1 2 2 3 4 1 7 0 10 5 5 1 2 1 1 7 7 8 1 1 3 1 1 1 3 3 1 6 0 10 1 8 2 4 1 1 1 2 7 2 3 1 1 1 1 2 1 8 0 10 3 4 2 5 2 1 8 2 7 2 3 1 1 2 1 1 1 3 3 1 2 1 3 7 1 6 0 11 4 1 2 1 7 9 2 1 6 9 1 1 1 3 1 3 2 1 7 0 7 6 1 4 1 6 4 5 3 1 2 3 1 2 2 1 9 0 9 1 2 9 6 1 8 9 4 2 1 3 3 2 1 1 1 2 3 5 3 1 1 2 4 1 3 7 1 8 0 7 9 1 1 4 6 3 8 1 2 3 2 3 3 1 3 1 8 0 9 9 5 7 6 1 9 1 1 3 1 1 1 1 2 1 2 1 1 7 0 10 9 1 1 1 2 8 6 8 3 6 1 1 2 1 3 1 3 1 3 2 4 5 1 3 4 6 5 4 5 5 3 3 7 1 7 0 11 2 3 7 4 8 3 9 4 1 2 5 2 1 1 2 1 2 1 1 9 0 10 2 7 4 1 4 1 2 3 9 1 3 1 1 1 2 1 1 2 2 1 6 0 6 1 5 8 6 8 1 1 2 1 1 2 1 5 2 3 3 1 2 3 3 6 1 8 0 7 5 1 4 1 2 7 3 1 1 3 1 2 1 2 2 1 5 0 7 5 1 6 3 4 3 4 3 1 1 2 1 1 5 0 11 2 6 5 1 6 3 2 2 4 8 1 1 2 3 2 1 4 1 3 5 2 1 3 4 1 9 0 9 8 3 1 9 8 5 8 5 2 2 3 1 3 3 3 1 2 2 1 5 0 7 6 9 3 9 3 1 1 1 2 1 1 1 1 8 0 7 1 5 2 6 5 5 5 2 3 2 2 1 1 2 2 1 4 2 2 3 7 1 9 0 10 8 5 1 1 7 6 9 5 9 6 3 3 3 3 2 1 2 1 1 1 9 0 10 1 6 3 6 4 3 9 8 8 7 3 3 1 1 3 2 2 1 1 1 6 0 11 6 1 8 5 1 9 2 4 5 5 2 2 3 1 1 3 1 2 3 4 1 5 5 2 3 4 1 7 0 11 9 8 9 1 4 6 8 5 3 7 6 2 2 1 3 1 1 1 1 8 0 8 4 1 1 1 9 7 7 8 1 1 3 3 3 1 1 1 1 9 0 6 4 7 1 6 2 9 1 2 2 1 3 3 1 1 1 2 3 1 1 3 1 3 5 5 3 4 1 6 0 10 8 9 8 5 9 2 7 1 3 5 3 3 3 3 2 1 1 6 0 11 1 9 3 6 5 4 4 7 7 3 1 1 3 1 1 3 1 1 9 0 10 4 4 1 3 8 3 2 1 8 4 1 2 1 3 2 1 1 1 3 3 1 5 2 3 4 1 5 0 10 9 5 4 4 1 7 5 9 1 7 1 3 1 1 2 1 8 0 9 1 8 8 5 2 4 9 1 9 2 2 3 1 3 3 3 1 1 6 0 7 2 3 1 1 3 3 1 1 2 2 3 1 1 4 3 3 4 3 6 1 6 0 8 3 1 7 7 6 3 9 7 3 1 3 3 3 1 1 7 0 7 1 7 4 2 1 1 7 1 3 1 3 1 1 1 1 8 0 11 5 9 7 1 9 3 4 6 9 7 8 2 3 2 2 1 3 3 3 1 1 1 5 4 2 3 7 1 8 0 6 5 9 2 3 1 9 1 2 3 1 2 1 2 2 1 6 0 10 1 4 9 1 1 3 5 4 5 8 2 1 1 1 3 3 1 6 0 6 1 3 8 1 7 3 3 1 1 1 3 1 5 2 2 1 2 2 2 3 4 1 9 0 7 4 7 1 1 7 8 4 2 3 3 3 2 2 2 1 3 1 7 0 7 8 1 7 2 6 8 1 1 1 2 2 1 2 2 1 6 0 6 3 7 1 3 3 3 2 3 3 2 3 1 2 3 1 5 4 1 6 3 5 4 5 3 5 1 7 0 10 7 2 5 8 4 9 1 5 1 3 1 2 1 2 2 2 2 1 8 0 11 6 5 3 6 5 1 7 3 6 4 2 1 1 3 1 3 3 1 1 1 8 0 11 1 6 4 7 5 1 7 1 6 1 2 3 1 1 1 2 2 2 1 2 3 4 5 3 3 6 1 9 0 9 7 4 5 5 3 1 9 1 6 2 1 2 1 1 3 1 2 3 1 9 0 8 1 5 3 8 3 1 8 3 1 3 1 3 2 2 2 2 1 1 6 0 11 3 9 1 3 1 7 3 2 7 6 8 2 1 1 1 1 3 2 1 5 3 5 3 3 6 1 8 0 6 1 2 5 5 5 3 2 1 2 2 3 1 3 2 1 7 0 8 1 9 5 9 2 9 9 5 3 1 2 1 2 2 3 1 7 0 10 3 8 2 8 9 5 1 1 6 4 2 1 1 1 2 1 3 2 4 5 3 4 3 3 5 1 9 0 11 5 6 3 1 5 9 9 1 7 6 6 2 1 3 1 3 3 1 2 1 1 8 0 9 8 2 5 1 1 5 8 5 2 3 1 2 2 1 1 1 1 1 7 0 9 2 9 8 1 1 2 1 1 2 3 1 3 3 3 2 1 1 1 5 2 2 3 5 3 1 6 5 4 3 4 1 6 0 7 2 6 5 4 6 1 8 1 2 3 3 2 2 1 8 0 11 3 2 6 7 1 1 2 1 7 9 2 2 3 2 3 1 2 1 2 1 9 0 10 3 5 3 9 2 1 5 8 9 5 1 3 1 2 3 1 3 3 1 2 5 2 2 3 6 1 9 0 9 1 3 9 3 4 8 4 5 1 1 3 3 2 3 3 1 3 1 1 6 0 11 6 1 5 6 3 5 2 2 4 6 3 1 1 1 2 2 3 1 6 0 7 8 1 1 3 6 1 3 1 1 1 1 3 2 2 5 3 1 4 1 3 6 1 8 0 7 2 9 9 2 3 3 1 2 3 3 3 1 2 2 3 1 7 0 6 6 1 2 7 4 5 2 2 2 1 1 2 2 1 9 0 9 8 3 1 4 7 8 8 2 1 2 1 1 2 1 3 2 3 2 2 4 1 2 2 1 3 5 1 8 0 7 3 4 9 1 2 1 3 3 2 1 3 3 1 2 2 1 8 0 10 2 8 1 8 5 5 4 8 5 3 2 2 1 2 1 1 1 2 1 6 0 8 9 9 3 1 7 6 4 6 1 2 3 2 3 1 2 2 5 5 5 3 5 1 9 0 10 2 6 3 7 6 1 3 1 9 6 3 3 3 3 1 3 2 1 3 1 5 0 9 2 2 4 4 1 6 8 2 8 2 2 1 2 1 1 6 0 11 3 2 1 1 4 6 6 8 3 2 3 3 3 1 3 2 1 4 1 1 1 5 5 3 3 1 5 3 3 4 1 7 0 8 7 2 3 2 6 1 9 1 3 2 1 3 2 1 1 1 6 0 6 3 1 6 4 7 5 1 2 2 3 1 1 1 8 0 8 2 9 3 6 5 5 3 1 1 1 2 1 2 2 2 3 4 1 5 2 3 6 1 7 0 9 7 1 4 9 2 7 1 1 6 1 3 1 1 1 2 1 1 9 0 9 3 8 5 1 2 8 2 9 1 1 1 1 2 2 3 1 2 1 1 9 0 11 5 1 3 5 7 5 7 2 7 1 1 1 2 2 3 2 1 3 1 2 4 4 3 1 4 1 3 6 1 5 0 9 7 6 1 4 3 8 8 7 7 1 3 1 1 3 1 5 0 11 8 5 6 8 6 5 1 6 9 1 3 2 1 1 1 3 1 5 0 7 2 3 4 1 9 5 2 2 1 2 2 1 3 1 3 1 1 5 3 5 1 7 0 6 3 2 8 8 6 1 2 1 2 1 1 2 2 1 9 0 11 8 1 2 1 6 7 3 4 6 6 3 3 2 1 2 3 2 1 3 2 1 5 0 10 1 1 2 1 1 4 1 6 7 9 2 3 2 1 2 3 2 3 2 3 3 5 1 6 0 7 5 4 1 7 2 2 7 2 2 3 3 1 1 1 9 0 7 8 3 3 1 2 4 8 1 2 3 3 2 2 1 3 1 1 6 0 7 1 1 8 1 7 3 2 2 2 1 2 1 3 2 3 3 3 4 3 5 1 3 9 1 7 3 5 5 3 4 1 7 0 7 3 4 4 4 1 3 5 3 3 2 1 2 1 2 1 7 0 9 6 3 1 5 1 1 8 6 9 3 3 1 2 3 1 2 1 9 0 9 3 4 7 1 5 8 6 5 1 3 2 2 1 2 1 1 3 2 2 3 4 4 3 5 1 5 0 10 7 1 2 8 7 5 5 2 6 2 1 2 1 2 3 1 9 0 7 4 3 6 1 5 9 2 1 1 2 1 1 2 2 1 2 1 9 0 9 5 9 1 1 2 7 8 7 5 3 3 3 3 3 1 2 2 3 2 3 2 5 3 3 5 1 9 0 6 4 2 9 9 1 5 1 2 1 2 1 1 1 1 3 1 5 0 11 3 1 3 4 5 5 7 9 5 1 8 1 1 3 3 1 1 9 0 11 8 9 2 5 5 6 3 9 1 1 8 1 2 3 2 1 1 2 1 2 3 3 4 3 4 3 6 1 5 0 11 7 9 9 7 8 4 9 6 1 1 8 1 3 2 2 3 1 7 0 6 8 9 1 9 6 2 2 2 1 2 1 2 1 1 8 0 7 9 8 7 1 4 3 1 3 1 1 1 2 3 3 2 5 1 1 3 4 4 3 4 1 8 0 9 5 3 9 1 6 7 2 1 2 1 1 3 2 1 2 1 2 1 5 0 9 7 9 5 5 6 6 4 1 6 2 1 2 3 1 1 7 0 6 1 5 3 9 1 4 2 2 2 2 1 1 1 3 1 4 5 6 2 1 1 6 4 3 3 4 1 5 0 8 4 8 7 1 6 1 7 2 1 3 3 1 1 1 6 0 8 2 4 3 1 3 9 7 1 2 2 1 1 1 3 1 9 0 6 1 5 1 9 9 1 2 1 3 2 1 3 2 1 1 1 4 1 4 3 6 1 6 0 6 1 1 5 9 8 1 3 2 1 3 1 1 1 5 0 8 1 5 1 5 2 5 6 8 2 1 3 1 3 1 7 0 10 1 3 3 7 7 4 3 8 3 1 1 1 1 1 2 3 3 2 2 3 4 4 2 3 7 1 5 0 8 5 4 1 7 3 2 5 4 1 2 3 3 1 1 6 0 9 8 8 1 8 5 4 4 1 8 3 2 1 1 1 2 1 7 0 9 7 4 1 1 7 4 4 5 3 3 2 1 2 2 1 1 3 1 2 3 2 3 1 3 4 1 6 0 11 1 9 2 3 3 3 5 1 3 7 5 3 2 2 2 1 1 1 5 0 11 1 2 8 3 9 5 5 2 6 8 1 1 1 2 2 3 1 6 0 7 1 7 1 9 5 8 7 2 3 1 2 2 3 1 3 1 2 5 1 2 4 3 3 7 1 6 0 11 5 4 1 9 6 4 1 4 9 6 6 1 1 1 1 2 2 1 9 0 6 1 4 9 5 6 1 3 2 3 1 1 1 1 1 2 1 9 0 7 7 2 9 1 3 8 8 1 2 2 3 3 1 2 1 2 2 1 1 2 5 3 2 3 4 1 5 0 7 7 1 5 9 5 1 1 2 1 3 2 1 1 7 0 6 1 1 6 9 6 5 2 1 3 1 3 3 1 1 9 0 10 6 4 3 1 3 9 6 1 6 5 1 2 3 1 3 2 2 3 2 3 1 1 2 3 4 1 7 0 8 3 1 6 1 1 9 8 4 2 1 3 2 3 2 1 1 6 0 7 1 3 5 6 8 3 3 3 3 1 1 1 1 1 9 0 8 3 1 4 7 6 2 2 5 3 1 2 3 1 1 1 3 3 3 4 2 2 3 4 1 6 0 6 4 3 1 2 3 3 3 2 2 3 1 2 1 7 0 11 6 2 1 1 3 6 6 4 2 2 1 3 1 3 3 1 1 2 1 6 0 10 9 9 2 1 4 3 8 9 1 8 2 1 1 2 2 1 1 4 2 5 1 1 1 5 3 3 5 1 5 0 10 5 8 2 3 1 9 4 1 4 8 2 1 3 3 1 1 8 0 8 4 1 1 9 1 3 8 7 2 1 1 2 3 3 3 3 1 9 0 9 6 4 7 3 1 4 1 6 1 1 1 2 1 2 3 3 3 3 2 5 5 1 3 3 5 1 9 0 7 7 1 3 5 4 6 9 2 3 2 2 3 3 1 3 1 1 5 0 8 1 4 1 6 6 9 4 1 1 3 2 2 3 1 7 0 9 1 8 4 1 1 7 8 9 6 1 3 2 1 1 1 3 4 1 5 1 2 3 4 1 6 0 10 8 4 2 4 3 7 6 1 1 9 1 1 3 3 2 1 1 5 0 10 6 7 3 4 3 1 3 1 9 5 1 1 2 2 2 1 6 0 7 1 8 6 7 7 6 1 3 1 2 3 3 1 3 3 5 1 3 6 1 5 0 6 3 8 4 1 1 9 1 1 1 2 2 1 9 0 9 5 4 9 9 9 8 1 6 2 2 2 2 1 3 2 2 2 1 1 8 0 11 2 4 1 2 5 4 8 8 9 6 2 2 1 2 2 1 1 3 3 2 3 1 1 3 2 3 4 1 6 0 7 8 7 6 9 1 8 4 1 3 1 3 1 2 1 7 0 7 1 6 2 1 6 1 1 3 1 1 1 2 3 2 1 8 0 11 3 5 6 1 5 4 3 3 9 2 6 3 1 1 2 3 3 1 1 3 3 5 4 3 7 3 5 5 3 4 1 7 0 11 9 3 5 5 1 4 4 8 5 2 4 3 2 3 2 2 1 1 1 9 0 7 5 3 9 8 6 4 1 2 1 1 1 2 2 1 1 3 1 7 0 7 3 3 1 2 4 6 7 1 1 2 3 1 2 1 1 1 2 2 3 6 1 5 0 9 2 9 5 4 9 5 7 4 1 2 2 2 3 1 1 7 0 9 2 1 8 6 7 3 2 5 5 3 3 1 1 1 1 1 1 8 0 11 3 1 5 8 3 6 1 5 3 7 5 2 2 3 3 3 3 1 3 4 1 3 3 3 2 3 5 1 7 0 9 3 3 1 3 1 1 9 8 7 2 2 1 3 3 2 2 1 7 0 10 8 6 2 3 9 1 8 1 1 1 2 3 1 3 3 1 3 1 7 0 11 4 5 4 1 1 2 2 9 8 5 3 1 1 3 3 1 1 3 4 2 1 2 5 3 7 1 6 0 8 6 1 6 8 1 1 5 5 2 3 3 1 3 3 1 9 0 7 3 3 9 5 1 7 1 1 3 2 1 2 3 1 2 1 1 9 0 7 1 7 2 1 2 2 4 3 3 1 3 3 3 3 1 1 1 1 4 5 3 3 3 3 5 1 9 0 10 9 1 4 6 7 1 5 9 7 6 1 1 3 2 1 3 2 2 1 1 7 0 6 7 1 8 5 5 8 2 3 1 1 2 1 3 1 6 0 9 9 7 1 1 3 8 7 4 7 1 1 3 2 1 1 5 4 4 2 1 5 4 7 1 2 4 3 3 6 1 5 0 10 6 3 8 2 5 4 1 2 2 8 2 1 2 1 1 1 6 0 7 3 2 9 2 1 4 4 3 1 3 1 3 1 1 8 0 10 3 1 4 2 4 9 1 5 5 9 2 2 2 3 1 1 1 3 5 3 2 4 3 2 3 7 1 8 0 11 7 1 2 2 3 1 4 9 5 9 6 1 3 1 3 2 3 1 2 1 7 0 10 9 7 5 6 4 1 7 9 2 2 3 1 1 1 1 2 1 1 6 0 9 1 8 6 7 5 5 4 3 4 2 3 1 2 2 1 4 4 3 3 3 2 4 3 4 1 5 0 7 1 8 1 5 9 6 6 3 1 1 2 2 1 8 0 6 6 4 4 1 6 5 2 2 2 2 1 2 1 3 1 6 0 9 7 5 3 1 9 9 1 7 2 1 1 2 2 1 3 3 5 5 1 3 7 1 7 0 8 4 3 4 1 4 8 8 4 3 2 3 3 2 3 1 1 9 0 7 7 3 8 1 7 6 5 1 1 3 1 3 3 2 1 3 1 7 0 6 9 6 3 6 9 1 2 2 1 3 2 1 3 2 5 5 3 2 3 1 6 3 3 4 5 3 7 1 5 0 6 3 9 6 9 1 1 1 2 2 1 2 1 7 0 9 3 4 9 1 9 7 3 8 2 1 1 1 1 1 3 3 1 7 0 7 9 4 7 3 2 1 1 1 2 1 2 3 1 3 3 3 5 1 5 2 4 3 6 1 7 0 11 3 1 7 4 7 2 1 3 3 5 1 2 1 3 1 2 2 2 1 5 0 6 7 8 5 1 4 9 1 2 1 2 1 1 7 0 10 1 5 2 4 1 4 8 9 9 3 1 1 3 1 3 3 1 3 2 1 2 5 4 3 6 1 9 0 8 8 4 5 3 8 2 1 7 1 1 1 1 3 2 1 2 2 1 6 0 8 1 1 8 4 5 7 1 6 1 2 1 2 1 2 1 9 0 11 8 8 3 1 6 5 6 8 1 8 9 1 1 3 2 1 1 1 3 2 1 5 3 4 2 4 3 6 1 9 0 6 1 7 6 1 5 2 1 3 3 2 1 2 1 1 2 1 6 0 8 4 7 1 1 3 9 6 4 3 2 1 2 3 1 1 9 0 10 8 9 6 9 1 4 3 8 2 5 1 1 1 3 1 1 1 1 1 1 5 2 2 5 2 1 2 4 5 4 1 9 7 7 3 5 3 3 7 1 6 0 11 6 6 1 7 1 9 2 9 8 3 6 2 3 1 1 1 3 1 5 0 7 5 8 6 1 9 6 4 1 1 1 1 3 1 5 0 6 1 8 6 4 5 4 1 1 1 3 3 2 2 3 2 1 1 1 3 7 1 5 0 10 5 3 6 2 1 2 2 1 3 4 3 3 1 3 1 1 5 0 8 3 4 8 4 1 4 8 5 3 2 1 2 1 1 9 0 10 4 7 4 9 3 1 7 6 1 7 2 2 3 3 1 2 1 2 3 3 1 1 1 5 2 4 3 5 1 9 0 6 6 7 1 5 1 7 1 2 1 1 2 1 1 3 1 1 6 0 11 7 4 1 7 1 1 5 1 5 9 5 2 1 1 2 3 3 1 8 0 10 5 8 4 5 7 2 6 1 3 9 2 1 3 1 3 2 1 1 2 2 2 2 1 3 7 1 7 0 9 5 6 1 3 2 2 1 1 8 3 1 2 1 2 2 2 1 9 0 6 1 2 4 8 5 8 1 2 3 2 1 3 2 1 3 1 5 0 10 4 9 4 9 7 3 4 8 5 1 1 2 1 3 3 2 3 4 3 2 3 2 3 5 1 5 0 6 1 1 8 5 7 8 2 2 1 1 1 1 6 0 9 3 3 6 1 1 1 1 7 4 2 2 3 1 3 1 1 6 0 8 5 9 2 5 1 7 5 3 3 2 3 1 1 2 5 1 3 1 3 3 4 4 4 3 3 5 1 9 0 11 3 5 9 5 9 8 9 4 1 5 7 2 1 3 1 1 1 3 1 1 1 7 0 8 5 4 1 3 8 1 3 3 1 1 1 1 2 1 3 1 6 0 10 6 2 3 3 7 7 1 5 3 1 3 1 2 1 2 2 1 4 1 3 3 3 4 1 7 0 8 6 1 1 2 1 1 3 5 2 3 1 1 2 2 1 1 8 0 8 5 7 9 8 1 7 1 8 2 3 1 1 1 1 1 3 1 9 0 10 4 1 6 9 2 1 1 7 3 8 3 1 3 2 2 2 2 3 3 4 1 1 2 3 7 1 6 0 6 2 1 8 1 2 5 1 2 3 3 1 3 1 8 0 6 2 1 1 7 1 1 1 1 3 1 1 3 1 2 1 6 0 11 1 8 9 4 6 9 5 7 2 7 5 3 3 1 1 1 1 3 3 5 2 1 4 3 3 6 1 9 0 11 5 7 4 5 9 1 3 4 5 6 8 1 2 2 3 3 1 2 1 1 1 6 0 8 4 7 1 5 1 6 8 9 2 2 2 3 1 2 1 6 0 9 6 2 7 1 1 9 1 5 3 1 1 1 1 1 2 1 5 1 2 2 1 5 2 3 5 4 3 5 1 9 0 10 5 5 4 1 8 5 5 7 6 1 3 1 2 3 1 1 2 1 1 1 6 0 11 1 5 4 1 8 7 6 5 8 9 5 1 3 2 3 1 1 1 9 0 10 1 1 7 3 9 4 1 6 5 1 3 1 1 1 2 2 2 1 3 2 3 3 4 1 3 6 1 9 0 9 4 4 9 1 4 5 4 6 2 1 2 1 3 2 3 2 3 2 1 8 0 6 1 1 2 7 9 1 1 2 1 1 1 3 1 1 1 9 0 10 7 3 7 1 1 1 9 9 4 5 1 2 1 1 2 1 2 3 1 4 4 1 2 3 1 3 7 1 6 0 11 2 1 9 7 4 6 1 6 2 6 5 1 2 2 1 1 3 1 8 0 11 1 5 5 4 6 5 4 1 1 6 3 2 1 1 3 1 1 2 1 1 7 0 10 5 8 2 5 1 4 1 1 6 4 1 1 1 1 1 3 2 1 2 4 3 1 1 4 3 4 1 5 0 6 6 8 1 8 5 9 1 1 1 1 2 1 8 0 11 4 2 9 5 1 1 4 1 4 5 8 1 1 3 3 3 2 2 3 1 7 0 9 1 5 7 2 3 9 7 6 2 2 2 1 1 3 2 2 4 2 4 3 3 4 1 8 0 6 5 6 8 1 3 1 1 1 2 3 1 3 1 3 1 7 0 10 1 7 5 9 7 4 4 3 1 8 3 1 3 3 1 1 2 1 5 0 11 4 3 2 1 9 2 8 6 1 4 7 3 1 2 1 3 4 3 3 4 6 4 5 7 5 4 3 5 1 5 0 8 9 3 1 5 7 2 9 1 1 3 3 3 3 1 5 0 6 3 7 3 1 7 1 2 2 1 1 1 1 7 0 8 8 1 8 1 9 6 3 7 2 3 3 1 1 1 2 4 4 1 5 3 3 6 1 7 0 11 2 5 3 2 7 9 4 1 7 5 9 1 1 3 1 1 3 1 1 8 0 11 1 7 6 1 3 9 1 5 2 2 4 3 3 2 1 1 1 3 2 1 6 0 10 9 3 4 8 7 1 7 1 7 7 2 3 3 3 3 1 4 3 1 3 3 4 3 4 1 8 0 6 3 4 1 8 4 3 2 3 3 2 3 1 1 3 1 6 0 9 7 4 8 2 1 4 8 1 3 2 2 2 2 1 1 1 8 0 9 1 1 3 2 5 2 1 3 6 3 1 2 1 1 2 1 3 4 3 3 2 3 4 1 8 0 10 4 5 2 6 2 2 1 1 1 5 2 1 3 2 1 1 1 2 1 5 0 7 7 5 7 1 7 9 6 2 1 1 1 3 1 5 0 6 6 5 1 1 8 6 1 1 2 2 1 4 5 2 4 3 4 1 6 0 8 2 3 9 9 4 1 1 2 1 1 1 2 1 3 1 9 0 10 8 8 8 2 8 6 9 4 1 3 2 3 1 3 1 1 1 3 1 1 5 0 11 7 1 9 1 2 8 3 3 3 3 5 2 1 2 1 3 3 1 2 5 2 5 1 1 5 5 3 7 1 8 0 10 2 2 1 9 2 8 2 1 5 3 1 1 2 2 3 1 2 1 1 6 0 8 5 3 7 3 7 7 1 1 2 2 1 1 2 3 1 9 0 6 1 3 9 8 5 1 3 2 1 2 3 2 1 3 3 2 5 2 5 5 2 3 3 5 1 5 0 10 2 1 6 2 5 4 1 7 8 4 1 1 3 2 3 1 6 0 8 3 6 7 7 5 9 8 1 1 2 1 1 1 3 1 6 0 6 9 1 4 8 3 4 3 2 1 2 2 1 1 5 3 1 2 3 4 1 5 0 9 1 1 7 4 1 8 1 6 2 1 1 1 2 1 1 9 0 6 4 6 3 3 2 1 1 2 1 3 2 1 1 1 2 1 8 0 8 1 5 3 6 1 5 8 6 3 3 2 1 1 1 1 3 1 5 5 4 3 5 1 7 0 10 5 1 1 1 9 2 6 5 4 8 2 3 1 3 3 1 1 1 9 0 9 9 7 7 3 1 2 5 1 7 2 2 1 2 1 2 2 3 2 1 7 0 8 4 2 6 9 2 4 1 3 1 3 2 1 3 3 1 3 5 1 2 1 3 7 1 7 0 7 4 6 5 5 5 5 1 1 3 3 2 1 1 2 1 7 0 8 5 7 5 5 2 1 6 8 1 3 2 3 1 2 1 1 7 0 9 8 4 8 5 9 1 3 8 9 3 1 3 3 2 2 1 2 2 1 3 5 2 3 4 6 7 5 5 5 4 3 6 1 9 0 7 6 9 9 3 3 8 1 1 3 3 2 2 2 1 2 1 1 7 0 9 8 9 9 5 1 9 2 1 2 1 3 2 1 1 1 3 1 5 0 7 4 1 8 7 9 3 1 3 1 1 2 1 3 3 4 4 3 4 3 7 1 8 0 10 4 5 5 7 7 5 1 5 5 8 3 3 2 2 1 2 1 3 1 7 0 11 5 8 1 1 1 7 7 9 8 8 3 2 1 2 3 3 3 2 1 7 0 11 1 6 6 9 5 2 1 4 3 6 8 3 2 3 1 1 1 2 5 1 2 3 1 4 1 3 6 1 9 0 10 5 7 4 4 3 8 3 3 1 6 2 1 1 3 2 1 3 1 3 1 7 0 6 7 3 8 9 3 1 3 3 2 3 3 1 3 1 6 0 6 1 7 3 7 9 2 1 2 3 3 1 1 3 3 2 4 4 2 3 4 1 5 0 8 9 7 8 7 9 1 6 4 1 2 3 1 2 1 7 0 10 7 2 9 9 3 1 9 9 5 9 1 3 1 1 1 1 1 1 5 0 6 6 4 7 1 8 5 2 3 2 1 1 4 4 3 3 3 4 1 5 0 9 7 8 1 5 6 2 3 1 2 1 2 3 1 2 1 6 0 9 8 2 1 2 8 5 7 3 8 3 1 1 1 2 2 1 7 0 9 1 1 2 5 9 7 1 2 1 1 3 2 1 1 3 1 3 1 5 1 4 1 6 3 5 5 3 6 1 7 0 7 4 1 5 4 6 7 4 3 1 1 3 1 1 2 1 9 0 9 4 6 9 1 6 3 9 5 3 3 3 2 1 3 2 3 1 2 1 9 0 11 6 4 5 7 1 4 9 4 2 6 4 1 1 2 2 2 1 1 3 2 1 2 4 5 5 1 3 5 1 9 0 10 7 3 1 9 7 8 2 1 9 1 1 3 1 1 1 3 2 1 2 1 6 0 8 1 3 6 1 2 6 6 1 3 1 1 2 2 3 1 6 0 9 8 4 2 9 3 8 9 2 1 1 3 2 1 1 2 2 1 3 3 2 3 4 1 9 0 11 2 1 5 3 4 4 9 2 4 1 1 1 2 1 2 3 1 2 3 2 1 9 0 9 3 3 2 6 4 1 9 3 4 1 1 2 1 3 3 2 3 1 1 9 0 8 1 1 2 2 4 8 9 8 1 3 3 1 2 1 3 3 3 2 1 4 4 3 7 1 6 0 8 4 5 4 8 4 5 8 1 3 1 1 3 3 1 1 5 0 7 3 3 7 7 3 1 6 3 1 1 1 1 1 9 0 6 5 9 7 4 1 8 2 1 3 2 1 1 2 1 3 5 3 5 4 1 2 3 3 5 1 7 0 7 7 1 5 8 4 5 2 1 2 3 1 1 3 2 1 6 0 11 9 7 8 1 4 3 7 7 4 6 4 1 2 2 1 1 1 1 9 0 7 5 2 6 1 6 2 1 3 3 3 1 1 1 1 2 3 4 4 1 1 3 5 6 1 1 1 8 8 1 6 3 4 5 3 5 1 7 0 11 9 1 7 4 4 1 7 5 3 1 6 1 2 2 1 1 2 1 1 9 0 9 7 1 4 8 3 8 4 1 7 3 2 3 1 3 2 1 2 3 1 5 0 8 4 1 6 2 9 3 4 4 2 3 2 1 2 3 4 1 4 3 3 6 1 8 0 6 3 1 1 6 6 9 2 1 2 3 3 3 1 1 1 5 0 9 1 5 1 1 9 7 8 4 8 2 1 3 1 3 1 5 0 7 1 9 4 7 9 3 1 1 2 1 3 1 1 1 3 3 3 3 3 5 1 6 0 8 8 7 6 7 8 1 2 6 1 1 2 3 1 2 1 5 0 6 1 4 7 9 6 6 2 1 3 1 1 1 5 0 8 1 6 6 2 4 5 3 2 1 1 1 1 2 4 3 3 1 4 3 7 1 5 0 11 4 6 1 5 3 5 7 5 6 2 9 3 2 2 1 1 1 6 0 10 3 9 7 5 9 6 3 1 3 2 1 2 2 1 1 2 1 8 0 10 1 5 5 2 2 4 2 1 2 2 3 3 1 2 3 1 1 1 3 2 3 1 3 1 1 4 2 6 4 4 5 3 3 5 1 9 0 6 9 4 8 2 1 8 1 3 1 3 1 1 1 2 2 1 9 0 10 2 8 3 6 6 2 5 1 3 8 1 3 1 1 1 2 3 2 3 1 6 0 8 8 2 9 1 8 5 2 1 3 1 3 2 3 3 4 2 3 3 1 3 6 1 7 0 8 1 3 2 8 9 3 1 1 3 2 1 1 3 1 1 1 5 0 6 1 7 2 9 6 7 3 1 2 1 3 1 7 0 11 5 2 5 9 3 1 6 6 1 7 7 1 2 2 3 3 2 2 3 5 1 3 4 2 3 4 1 9 0 11 4 6 9 1 8 1 1 6 9 5 6 1 1 2 2 1 3 2 1 1 1 8 0 6 1 6 5 2 9 4 2 1 1 3 1 3 2 1 1 6 0 6 7 2 1 4 7 4 1 1 1 3 3 2 5 3 3 4 3 6 1 6 0 6 1 5 2 1 9 9 1 3 3 3 2 1 1 6 0 11 2 6 5 7 5 8 2 1 5 8 4 1 2 2 1 3 2 1 5 0 10 5 3 1 5 8 1 9 5 6 1 3 3 1 1 3 2 4 1 5 3 5 3 5 1 6 0 10 5 2 5 8 9 9 7 4 4 1 3 1 2 3 2 3 1 5 0 10 1 2 6 2 3 9 1 5 2 7 1 2 3 1 2 1 7 0 10 1 3 6 9 5 3 4 6 8 3 3 1 2 1 1 3 2 1 2 1 4 2 5 4 7 5 4 3 4 1 9 0 6 8 7 1 1 7 4 1 2 1 2 1 3 3 1 3 1 5 0 11 7 6 7 3 5 5 1 1 4 1 1 1 3 1 2 1 1 6 0 7 4 2 9 5 1 7 1 1 3 1 3 3 2 2 5 5 3 3 6 1 8 0 11 3 5 3 9 1 5 6 6 1 6 1 2 3 1 2 1 2 1 2 1 7 0 7 1 8 4 7 6 8 6 1 1 2 1 1 3 1 1 9 0 8 9 5 1 2 7 7 8 7 1 1 3 1 2 2 1 3 3 1 4 3 1 5 1 3 4 1 7 0 8 9 7 1 2 2 6 5 1 3 1 2 1 1 1 2 1 5 0 11 8 6 1 2 3 7 9 5 6 5 1 1 2 2 1 3 1 6 0 10 8 7 5 5 7 6 6 9 1 6 3 1 2 1 1 1 1 2 2 5 3 5 1 7 0 7 2 1 4 6 7 2 7 3 1 1 2 3 1 1 1 8 0 8 1 4 8 9 1 8 4 6 2 1 1 1 2 3 1 3 1 9 0 9 9 7 1 7 8 8 3 4 2 3 3 1 2 1 3 2 1 3 2 2 3 2 4 3 4 1 7 0 8 8 7 1 1 3 4 2 1 3 3 2 1 2 1 2 1 7 0 10 7 6 9 5 1 2 1 1 4 4 1 1 1 3 1 1 2 1 7 0 11 8 2 4 2 9 1 5 4 5 3 2 1 1 3 1 3 1 1 4 1 1 1 4 5 3 3 5 3 3 6 1 6 0 11 9 3 4 7 2 6 2 4 4 1 4 2 2 2 1 1 3 1 5 0 8 1 5 1 3 4 7 1 9 1 1 2 1 1 1 9 0 6 8 1 3 8 7 6 1 3 3 2 1 1 3 1 2 5 3 5 2 3 1 3 6 1 5 0 7 1 8 2 4 1 4 4 2 1 1 1 3 1 7 0 6 8 1 9 1 9 5 2 1 1 1 3 3 1 1 5 0 11 5 3 9 4 1 2 9 4 9 5 6 1 1 1 2 1 5 3 5 2 2 4 3 4 1 7 0 7 4 5 1 5 8 2 2 2 1 1 1 1 1 3 1 9 0 7 8 5 6 3 4 9 1 3 3 3 2 2 2 1 2 3 1 9 0 6 1 2 1 1 4 9 1 1 1 2 2 2 1 2 2 3 2 3 2 3 5 1 7 0 8 7 5 5 8 1 1 3 7 3 3 2 1 3 3 3 1 6 0 10 1 2 7 2 1 3 4 3 9 1 1 3 1 2 1 1 1 7 0 11 3 7 5 1 3 1 1 1 1 5 1 1 2 1 1 1 2 3 5 3 2 4 1 3 4 1 5 0 7 6 3 8 4 9 5 1 2 2 2 1 2 1 5 0 7 6 8 4 5 9 9 1 1 1 1 3 1 1 7 0 10 6 6 5 2 7 1 2 9 7 6 1 2 2 1 2 3 1 5 2 4 4 5 6 1 5 5 3 4 1 9 0 6 8 7 1 6 1 7 2 2 1 1 3 2 2 3 2 1 8 0 8 3 5 3 7 5 4 8 1 2 1 2 2 2 2 2 1 1 5 0 6 9 6 1 5 3 1 1 3 2 1 1 5 1 3 3 3 7 1 9 0 8 5 1 6 1 6 5 7 1 2 1 3 1 1 3 3 1 1 1 7 0 7 1 1 2 6 1 1 9 1 3 2 1 3 1 2 1 6 0 6 8 3 8 4 1 6 1 1 2 3 3 2 5 2 5 5 2 1 2 3 4 1 9 0 9 8 5 3 7 8 6 1 3 9 2 3 2 2 2 1 3 2 2 1 5 0 10 3 4 6 8 9 1 8 9 2 7 1 2 1 3 1 1 7 0 7 9 6 8 1 5 2 1 3 2 3 1 1 1 1 3 3 1 2 3 6 1 7 0 11 7 1 1 5 4 2 8 5 4 2 4 2 2 2 1 1 2 1 1 8 0 9 1 5 2 6 6 7 5 6 1 2 2 3 1 2 1 1 2 1 6 0 10 4 8 3 5 9 5 8 1 2 2 2 2 2 3 3 1 2 2 1 1 3 1 3 6 1 7 0 7 4 6 1 2 1 1 3 1 3 1 1 3 3 3 1 8 0 10 5 1 6 1 1 4 8 2 8 5 2 2 1 1 2 2 2 1 1 7 0 7 7 6 2 1 2 8 1 3 1 3 3 3 2 2 3 5 1 4 1 3 3 2 6 2 3 5 3 3 7 1 8 0 7 2 6 2 5 1 5 2 1 1 3 1 3 2 3 3 1 8 0 7 1 1 3 1 1 9 5 3 2 1 1 2 3 3 1 1 5 0 6 1 5 4 4 1 9 1 1 1 1 2 1 3 5 3 3 3 1 3 7 1 8 0 6 2 2 3 1 4 2 1 3 1 2 2 2 1 2 1 9 0 7 8 5 7 9 7 1 1 1 3 1 3 2 2 1 1 1 1 9 0 9 5 3 2 1 3 1 3 1 1 3 2 3 3 3 3 1 1 3 3 3 1 5 5 4 1 3 5 1 5 0 9 6 2 2 9 3 7 7 1 3 3 3 2 1 1 1 6 0 7 1 1 3 9 6 6 7 2 1 3 3 3 2 1 5 0 7 6 3 2 1 8 2 8 1 2 3 1 3 2 1 2 2 1 3 5 1 5 0 6 1 1 1 8 3 4 3 3 1 3 3 1 6 0 9 9 1 2 8 4 6 2 8 1 3 2 3 2 1 2 1 8 0 11 9 3 2 3 1 7 2 6 7 1 5 1 1 2 1 3 1 2 3 4 2 3 5 1 3 4 1 6 0 9 3 8 2 2 7 4 1 8 7 1 1 3 3 2 1 1 6 0 11 2 3 1 7 8 7 1 5 2 2 5 3 3 1 3 3 3 1 9 0 6 1 1 4 5 2 5 2 1 3 2 2 1 2 2 1 5 4 4 2 1 5 1 6 8 7 3 10 3 4 5 6 4 3 6 7 5
diff --git a/2018/src/day8.rs b/2018/src/day8.rs
new file mode 100644
index 0000000..81f0d0b
--- /dev/null
+++ b/2018/src/day8.rs
@@ -0,0 +1,66 @@
+use std::io;
+use std::io::BufRead;
+
+pub fn main<T: BufRead>(reader: T) -> io::Result<(String, String)> {
+ #[derive(PartialEq, Eq)]
+ struct Entry {
+ nch: i32,
+ nmeta: i32,
+ }
+
+ let mut stk = vec![Entry {nch: 1, nmeta: 0}];
+ let mut total_meta = 0;
+ let mut vals: Vec<Vec<i32>> = vec![vec![]];
+ let mut current_val = 0;
+
+ for num in reader.lines().next().unwrap().unwrap().split(' ').map(|s| s.parse::<i32>().unwrap()) {
+ // Yay non-lexical lifetimes!
+ let l = stk.last_mut().unwrap();
+ if l.nmeta == -1 {
+ // println!("read nmeta {}", num);
+ l.nmeta = num;
+ continue;
+ }
+
+ if l.nmeta == 0 && l.nch == 0 {
+ loop {
+ // println!("pop");
+ stk.pop();
+
+ // println!(" node value {}", current_val);
+ vals.pop();
+ vals.last_mut().unwrap().push(current_val);
+ current_val = 0;
+
+ let l = stk.last().unwrap();
+ if l.nmeta != 0 || l.nch != 0 { break; }
+ }
+ }
+
+ let l = stk.last_mut().unwrap();
+ if l.nch == 0 {
+ // println!("+meta {}", num);
+ total_meta += num;
+
+ if vals.last().unwrap().len() == 0 {
+ // println!(" add value");
+ current_val += num;
+ } else if 1 <= num && num <= vals.last().unwrap().len() as i32 {
+ // println!(" add child value {}", vals.last().unwrap()[num as usize - 1]);
+ current_val += vals.last().unwrap()[num as usize - 1];
+ }
+
+ l.nmeta -= 1;
+ } else {
+ // println!("read nch {}", num);
+ l.nch -= 1;
+ stk.push(Entry {nch: num, nmeta: -1});
+ vals.push(vec![]);
+ }
+ }
+
+ let part1 = total_meta.to_string();
+ let part2 = current_val.to_string();
+
+ Ok((part1, part2))
+}
diff --git a/2018/src/main.rs b/2018/src/main.rs
index fccb319..8d2f368 100644
--- a/2018/src/main.rs
+++ b/2018/src/main.rs
@@ -16,8 +16,9 @@ mod day4;
mod day5;
mod day6;
mod day7;
+mod day8;
-static NUM_DAYS: i32 = 7;
+static NUM_DAYS: i32 = 8;
fn day_switch<T: BufRead>(day: i32, reader: T) -> io::Result<(String, String)> {
match day {
@@ -28,6 +29,7 @@ fn day_switch<T: BufRead>(day: i32, reader: T) -> io::Result<(String, String)> {
5 => day5::main(reader),
6 => day6::main(reader),
7 => day7::main(reader),
+ 8 => day8::main(reader),
_ => Err(Error::new(ErrorKind::Other, "Invalid day"))
}
}