diff --git a/Sources/AOC2018/data/day08.txt b/Sources/AOC2018/data/day08.txt new file mode 100644 index 0000000..9cc43cf --- /dev/null +++ b/Sources/AOC2018/data/day08.txt @@ -0,0 +1 @@ +8 11 7 2 5 4 3 6 1 9 0 8 8 4 7 6 5 9 9 1 1 1 3 1 2 3 1 1 3 1 6 0 6 7 7 9 1 6 1 2 3 1 1 3 2 1 8 0 9 1 1 6 7 6 4 6 5 7 3 3 2 3 2 1 1 3 2 1 3 2 2 5 3 6 1 9 0 11 4 6 5 1 3 5 9 1 1 1 8 3 2 1 1 3 2 2 1 1 1 5 0 6 9 6 9 2 9 1 2 1 1 1 3 1 9 0 7 4 3 2 1 2 6 7 2 2 1 1 3 1 3 2 1 5 4 2 4 1 2 3 4 1 8 0 11 4 8 1 9 7 2 5 5 8 3 8 2 1 1 1 1 3 3 3 1 6 0 8 4 1 1 2 3 8 9 3 2 3 1 2 1 2 1 7 0 11 9 4 1 1 9 4 7 5 6 2 5 1 3 1 3 1 1 1 4 2 1 4 3 7 1 8 0 10 5 6 8 5 2 1 7 1 1 6 3 1 3 1 3 3 2 1 1 6 0 9 2 1 1 8 3 7 6 1 4 2 2 3 1 1 1 1 7 0 8 3 9 3 1 3 8 6 1 1 1 3 3 1 2 3 1 5 1 4 2 5 5 3 6 1 5 0 6 8 3 4 5 1 2 1 1 1 2 1 1 7 0 10 5 1 1 3 1 7 1 9 5 7 2 2 3 3 2 1 1 1 8 0 10 5 1 1 7 1 5 8 6 8 8 3 2 1 2 1 1 3 3 1 5 1 1 4 2 2 1 4 7 4 5 3 4 1 9 0 9 4 7 9 1 4 6 2 9 1 2 1 1 3 1 2 2 2 1 1 9 0 6 7 2 6 4 1 2 1 1 3 3 2 2 3 3 1 1 5 0 8 6 9 2 3 4 1 5 5 1 1 2 1 2 2 2 3 4 3 4 1 6 0 10 3 6 1 2 7 5 5 1 8 2 2 2 3 1 1 3 1 5 0 8 8 1 7 3 6 1 1 6 3 2 1 2 3 1 9 0 10 1 9 3 5 5 8 2 3 3 7 3 1 3 3 1 1 2 1 3 1 3 3 2 3 7 1 8 0 7 6 1 7 4 9 1 5 3 2 2 2 1 3 1 2 1 9 0 11 4 5 7 3 4 9 1 5 1 9 1 3 2 1 1 2 2 3 1 1 1 6 0 6 1 3 4 6 5 9 1 1 2 1 1 1 3 1 5 4 1 2 4 3 6 1 9 0 11 1 1 7 5 9 3 3 3 2 6 1 3 1 3 3 2 1 1 1 2 1 8 0 11 7 6 4 1 6 9 4 9 6 4 9 2 3 3 1 3 1 3 3 1 9 0 6 9 1 7 2 8 8 3 3 2 1 3 2 2 1 1 4 5 1 2 1 1 2 6 6 5 6 4 4 3 7 1 9 0 7 3 8 1 9 5 8 9 3 1 1 2 1 2 3 2 2 1 7 0 11 9 3 1 7 4 2 8 3 9 9 3 2 1 2 3 1 1 2 1 6 0 9 3 3 5 1 9 2 8 7 7 2 1 3 3 1 2 3 1 1 4 1 3 1 3 4 1 9 0 11 3 1 3 6 4 3 6 3 3 8 7 1 2 1 2 1 3 1 1 3 1 8 0 10 8 1 4 9 1 8 7 6 4 6 2 3 1 3 2 3 2 1 1 5 0 10 2 5 1 3 3 2 6 1 9 2 2 1 1 2 2 2 3 5 2 3 5 1 7 0 10 9 5 4 8 8 9 1 4 2 7 2 1 2 3 3 2 1 1 6 0 7 2 6 1 1 4 7 9 2 1 1 2 1 3 1 8 0 8 8 3 2 1 8 1 2 5 1 3 2 1 2 3 2 1 2 5 5 2 1 3 7 1 6 0 6 1 8 8 9 7 3 1 3 2 1 3 1 1 8 0 7 4 6 3 1 7 2 5 1 3 1 2 3 2 3 1 1 6 0 7 4 7 2 1 2 3 2 3 2 1 2 3 3 5 1 1 4 5 4 2 2 4 4 4 5 3 3 5 1 9 0 7 8 1 1 3 9 1 1 2 1 3 3 3 3 1 2 3 1 5 0 9 5 8 4 1 5 9 7 5 9 3 1 3 1 3 1 9 0 11 7 7 4 2 2 1 7 1 9 1 2 2 1 2 3 1 3 1 1 3 3 1 2 3 4 3 7 1 8 0 10 3 8 4 5 8 1 6 6 8 4 1 1 3 2 1 1 3 1 1 6 0 11 6 4 1 3 6 4 3 6 4 4 3 1 1 3 2 1 2 1 7 0 8 9 8 8 3 3 3 5 1 3 1 1 3 2 1 3 3 5 5 4 5 3 1 3 4 1 5 0 6 8 9 6 1 1 8 3 2 1 2 1 1 6 0 10 1 5 9 8 8 2 3 4 8 3 3 1 2 1 1 3 1 5 0 11 8 8 5 5 8 6 1 9 2 2 3 1 1 1 1 3 3 2 3 5 3 4 1 5 0 9 5 6 2 2 4 1 1 5 1 1 1 1 2 1 1 8 0 8 9 1 4 5 5 1 8 1 2 1 1 2 2 1 3 3 1 6 0 6 8 4 2 1 1 1 2 1 2 3 3 3 5 5 3 5 3 7 1 8 0 11 5 4 4 6 4 4 6 3 3 4 1 3 3 1 1 3 3 1 3 1 5 0 10 7 5 4 2 4 4 6 8 2 1 3 1 1 3 3 1 6 0 11 4 8 6 9 5 7 3 1 1 4 1 2 1 1 1 2 2 5 2 4 2 2 4 3 1 2 3 5 5 3 6 1 9 0 9 6 7 2 6 8 9 6 1 2 1 3 2 1 3 1 1 1 3 1 5 0 10 4 9 8 1 2 9 1 6 6 7 1 1 1 3 2 1 6 0 8 1 1 8 8 6 2 6 2 1 3 1 3 2 1 2 3 2 4 3 1 3 5 1 5 0 11 1 6 7 8 6 9 3 9 3 9 5 3 1 3 1 1 1 6 0 11 1 2 8 1 7 3 3 1 7 3 6 1 1 3 3 2 1 1 9 0 10 6 9 2 9 6 4 9 6 1 4 1 1 1 2 1 1 2 1 3 2 2 2 1 3 3 7 1 9 0 6 1 2 1 9 3 2 1 3 2 3 3 2 2 1 2 1 9 0 7 1 1 7 3 4 7 4 2 1 1 1 1 3 1 2 2 1 7 0 10 1 1 1 5 4 8 1 2 1 7 3 2 1 2 1 3 1 5 4 3 2 5 2 1 3 6 1 5 0 6 6 1 9 5 5 7 3 1 3 1 1 1 6 0 6 1 4 1 1 2 2 1 1 1 1 1 1 1 9 0 6 4 9 2 1 5 6 2 1 3 1 1 1 3 1 1 4 4 2 3 2 1 3 4 1 6 0 9 9 5 1 5 9 7 9 6 1 1 3 3 3 1 1 1 6 0 7 8 7 8 7 1 4 5 3 1 2 2 2 2 1 9 0 11 4 4 9 9 1 3 2 2 1 1 1 1 1 1 2 3 2 1 2 2 4 2 1 5 5 1 6 6 5 5 3 3 7 1 5 0 6 7 8 8 1 2 4 1 2 3 1 1 1 9 0 9 6 1 3 9 2 4 5 6 8 2 3 1 3 2 3 2 1 2 1 9 0 10 1 4 9 1 8 8 9 1 2 4 1 3 2 1 1 1 2 3 1 2 5 2 1 4 5 2 3 7 1 9 0 7 5 1 7 1 8 8 3 1 3 1 2 2 2 1 1 2 1 5 0 11 8 1 7 9 1 7 4 9 7 8 8 1 3 3 3 1 1 8 0 6 5 3 2 1 5 8 1 1 1 1 1 1 1 1 3 5 3 4 4 2 2 3 4 1 6 0 10 4 5 8 1 6 4 2 7 6 8 2 1 2 3 1 3 1 7 0 6 1 1 7 8 7 8 1 2 1 1 2 2 1 1 5 0 11 1 4 6 7 1 5 6 7 1 7 6 3 3 2 1 3 5 3 5 4 3 4 1 7 0 6 4 6 9 4 1 2 3 3 1 3 1 1 1 1 6 0 9 4 8 5 7 1 2 8 7 4 2 1 1 1 2 2 1 7 0 8 1 3 2 4 9 1 3 1 1 3 3 3 2 2 2 1 1 1 3 3 4 1 9 0 8 9 6 1 1 4 6 6 6 1 2 1 1 3 1 2 3 1 1 7 0 7 8 8 1 3 5 7 8 3 3 2 3 1 3 2 1 9 0 10 9 7 1 3 2 2 4 2 1 1 1 3 3 2 1 1 2 2 3 1 2 5 2 5 2 7 4 5 3 6 1 9 0 8 1 8 1 7 9 8 1 7 1 1 3 3 1 1 3 2 2 1 8 0 8 7 5 6 2 3 3 1 7 3 1 1 1 3 1 1 3 1 9 0 10 1 1 3 7 6 2 2 5 5 4 2 3 3 2 1 1 1 2 2 4 4 2 1 3 1 3 5 1 7 0 8 3 7 1 6 7 3 5 9 3 1 1 3 2 2 3 1 7 0 9 2 7 8 7 5 9 2 8 1 1 2 2 1 2 2 3 1 6 0 11 5 1 6 3 1 3 1 4 4 9 2 1 3 1 2 2 3 2 1 1 3 5 3 6 1 9 0 11 1 4 8 8 7 9 6 1 3 9 5 1 3 2 2 3 1 1 2 1 1 8 0 11 3 6 5 1 3 1 4 9 5 4 1 3 1 1 3 2 2 2 1 1 6 0 10 2 1 5 4 1 9 8 7 5 7 2 2 3 1 3 1 5 3 1 1 3 3 3 6 1 8 0 6 3 4 8 1 1 1 3 2 2 3 3 3 3 1 1 8 0 11 3 9 7 2 1 1 7 9 6 5 2 1 2 3 1 3 1 1 2 1 7 0 10 4 9 5 1 2 7 2 1 8 3 2 3 2 1 1 3 3 5 2 1 1 4 2 4 4 2 5 2 5 5 7 2 5 3 3 6 1 7 0 8 2 3 4 2 4 8 1 1 3 1 1 2 1 3 3 1 7 0 11 7 8 4 6 4 9 4 8 7 4 1 3 2 3 3 2 3 1 1 5 0 9 7 5 4 1 6 7 6 3 9 1 2 1 1 3 5 2 2 2 2 1 3 6 1 6 0 10 8 7 1 2 1 3 9 7 4 5 3 3 1 2 2 1 1 9 0 10 1 1 8 6 9 4 2 1 6 5 2 1 1 1 2 1 3 3 2 1 5 0 9 4 5 2 5 5 3 1 3 2 1 1 2 3 3 3 5 2 2 5 1 3 5 1 8 0 10 5 6 1 1 3 9 5 5 3 3 1 3 1 1 2 1 1 2 1 8 0 11 8 4 2 6 2 4 4 9 9 2 1 3 1 1 2 1 3 3 2 1 9 0 9 4 1 5 2 4 8 8 2 6 2 3 3 1 3 3 1 1 1 1 1 5 3 3 3 4 1 6 0 10 2 1 4 7 3 9 5 3 7 1 2 2 1 2 2 2 1 5 0 6 2 2 6 1 1 1 2 1 1 3 1 1 7 0 10 7 4 3 6 3 3 1 1 1 8 3 1 3 1 2 3 2 3 3 3 3 3 6 1 8 0 6 4 1 5 1 9 9 2 1 2 1 1 1 3 2 1 7 0 10 8 1 4 2 6 6 6 6 1 6 1 1 2 2 1 1 1 1 7 0 8 4 1 8 9 3 9 4 3 1 2 1 1 2 3 2 5 1 4 1 3 1 1 5 6 4 4 3 4 1 5 0 9 5 2 4 6 3 8 4 5 1 1 1 3 3 2 1 8 0 11 7 7 6 1 5 1 5 5 4 9 8 1 3 1 1 2 2 3 2 1 8 0 8 1 1 9 6 1 6 1 6 1 3 3 1 3 2 3 3 1 5 5 1 3 5 1 6 0 8 6 7 1 1 2 4 6 3 1 1 1 2 3 1 1 7 0 7 8 2 4 7 1 1 9 2 3 1 2 1 3 2 1 5 0 8 1 4 4 2 5 8 2 1 2 3 1 3 2 5 3 4 4 2 3 5 1 9 0 10 3 3 5 3 7 3 4 4 4 1 2 1 3 3 1 3 2 1 3 1 5 0 11 3 8 1 7 6 9 1 1 7 6 2 2 3 3 3 1 1 8 0 10 3 3 9 4 5 5 3 5 1 3 3 2 3 2 2 3 2 1 2 3 4 5 3 3 7 1 8 0 7 1 6 2 2 1 6 6 1 1 2 1 3 3 1 1 1 5 0 10 7 8 1 7 2 1 8 4 3 1 1 2 1 1 2 1 5 0 7 6 4 8 4 4 1 4 2 2 1 2 1 5 5 1 1 5 5 1 3 1 1 5 4 4 3 4 1 6 0 9 1 6 7 3 2 1 3 4 6 1 1 2 2 3 1 1 9 0 7 2 8 1 2 4 7 4 2 2 2 2 1 2 2 1 1 1 5 0 7 6 7 5 3 9 1 5 3 2 3 1 3 5 1 2 1 3 5 1 6 0 10 6 3 1 1 7 7 4 9 3 5 2 1 2 3 2 1 1 5 0 9 8 4 3 8 1 4 5 9 9 1 1 1 2 3 1 9 0 6 1 6 7 2 3 1 2 3 1 1 2 3 1 1 1 1 1 3 3 1 3 4 1 7 0 6 9 5 1 1 9 3 3 2 1 1 1 1 3 1 6 0 10 9 1 3 5 6 1 8 4 6 1 3 1 2 2 1 2 1 8 0 6 8 4 1 7 9 5 1 2 1 1 3 2 1 1 5 2 3 4 3 7 1 9 0 11 1 1 7 2 2 2 6 5 4 4 1 1 3 1 3 1 3 3 1 1 1 5 0 10 9 7 5 6 1 5 9 6 2 7 1 2 2 1 2 1 5 0 8 4 4 4 1 1 6 9 4 2 2 3 3 1 4 3 1 1 1 3 1 3 3 2 3 5 5 3 6 1 6 0 11 1 7 4 1 3 1 2 6 4 8 1 3 2 3 3 1 2 1 7 0 7 3 9 3 1 1 3 6 1 1 2 1 2 3 2 1 9 0 10 4 8 4 4 5 6 1 2 1 8 1 3 2 3 3 1 2 2 2 5 2 5 2 5 3 3 6 1 7 0 10 8 1 3 9 7 4 6 9 3 4 1 2 1 2 2 2 2 1 7 0 10 5 5 6 7 2 6 1 2 3 9 2 1 3 2 1 1 1 1 6 0 7 3 5 2 8 2 2 1 1 2 1 2 3 1 4 5 5 3 4 3 3 7 1 8 0 8 7 3 6 1 2 4 6 5 1 1 3 3 2 3 1 3 1 6 0 6 1 5 5 5 4 4 3 1 2 3 3 1 1 5 0 9 1 2 6 9 1 4 9 3 2 2 2 1 1 2 1 2 2 5 3 2 3 3 7 1 6 0 10 1 9 3 7 1 8 8 2 9 1 1 3 1 3 3 1 1 9 0 7 6 6 7 4 2 9 1 3 3 1 3 2 3 1 1 1 1 8 0 10 2 5 6 9 4 1 4 8 7 4 1 1 2 2 3 1 1 2 1 2 1 5 1 1 1 3 5 1 6 0 11 7 9 3 1 9 5 1 5 2 7 2 2 3 1 1 1 1 1 7 0 10 4 7 9 2 5 5 8 9 1 3 3 3 1 2 3 1 1 1 8 0 10 3 4 7 8 1 1 4 6 9 7 2 1 3 2 1 1 3 3 2 1 2 1 2 2 2 5 3 2 4 5 3 5 1 5 0 7 3 3 8 3 9 7 1 1 3 1 1 2 1 8 0 10 3 4 2 1 2 8 4 9 6 5 1 1 1 2 1 2 1 3 1 9 0 7 9 9 3 1 7 5 5 2 2 2 1 1 1 2 2 2 2 2 1 2 2 3 5 1 5 0 6 5 5 9 2 8 1 2 2 1 1 3 1 9 0 8 9 7 7 1 6 7 1 8 3 3 2 2 3 3 1 1 2 1 9 0 10 8 4 7 3 1 3 3 7 3 7 1 1 3 3 1 3 1 1 3 5 3 4 3 1 3 4 1 9 0 8 2 4 5 7 6 1 6 2 1 1 3 2 1 3 3 1 2 1 8 0 6 1 9 6 1 5 1 3 1 2 3 2 3 3 1 1 7 0 11 3 6 1 6 9 1 8 8 2 1 7 1 1 1 1 2 3 3 2 5 5 3 3 7 1 5 0 9 1 9 1 3 2 3 6 4 8 3 1 3 1 2 1 5 0 9 6 6 8 1 9 5 6 1 1 1 3 2 1 3 1 7 0 10 2 6 6 1 1 9 6 2 9 7 2 1 3 1 1 3 3 2 5 3 5 2 3 2 5 5 1 4 5 5 5 3 5 1 7 0 6 2 9 2 4 2 1 1 1 1 1 2 1 1 1 5 0 11 8 1 9 5 1 3 1 5 6 6 2 2 1 2 1 2 1 5 0 9 7 7 9 9 9 7 7 1 1 2 1 2 3 2 5 3 3 3 5 3 4 1 7 0 6 2 1 6 9 5 4 1 3 3 3 1 3 2 1 9 0 7 1 5 1 3 8 3 8 2 1 1 3 1 2 3 1 3 1 7 0 8 6 1 8 9 8 1 7 1 3 3 3 3 3 1 1 4 2 4 1 3 5 1 5 0 7 1 4 4 8 6 5 6 2 3 1 2 2 1 5 0 7 4 5 6 1 5 4 9 3 2 1 1 3 1 5 0 6 1 2 9 1 5 8 1 2 1 1 1 3 1 3 2 1 3 7 1 6 0 6 8 6 2 1 3 2 3 3 1 1 1 3 1 5 0 9 3 1 1 1 3 3 3 3 8 1 2 1 2 1 1 9 0 6 8 3 6 1 4 6 2 1 3 2 2 3 2 3 2 1 3 2 4 1 2 3 3 7 1 9 0 8 8 1 8 1 5 1 5 5 3 3 1 2 2 3 1 3 2 1 5 0 9 5 8 8 7 7 1 7 1 1 1 2 1 3 3 1 8 0 7 8 9 3 8 1 3 6 1 2 1 1 2 3 1 3 3 1 5 3 5 2 2 3 2 7 2 2 5 5 3 4 1 6 0 6 2 5 6 1 1 1 1 2 1 3 2 2 1 6 0 7 6 2 5 1 1 9 3 2 2 1 2 3 2 1 5 0 9 5 7 3 2 6 1 1 5 2 1 1 1 3 2 3 1 5 1 3 4 1 7 0 7 1 8 8 6 6 1 9 1 1 1 2 1 3 1 1 7 0 7 9 3 1 1 8 6 7 1 1 3 2 1 2 3 1 5 0 6 4 1 1 8 4 4 1 1 2 1 1 3 5 1 1 3 4 1 6 0 7 9 1 8 2 1 2 3 3 2 2 2 3 1 1 6 0 6 3 5 5 2 1 1 1 3 1 1 1 1 1 5 0 6 1 9 6 4 5 7 3 1 2 1 2 1 1 5 3 3 4 1 7 0 7 3 6 7 2 9 2 1 3 1 1 3 1 3 1 1 6 0 8 5 5 1 5 9 3 9 8 2 1 3 1 1 1 1 9 0 6 6 1 8 2 8 6 2 3 3 1 3 2 2 3 1 1 4 3 4 3 7 1 9 0 7 7 5 5 1 1 4 1 2 1 1 2 2 1 3 2 3 1 7 0 11 3 1 6 8 6 3 8 7 7 6 9 2 3 2 1 1 2 2 1 8 0 6 2 2 1 8 9 9 1 1 1 1 1 1 3 1 3 2 1 5 1 5 2 5 5 6 5 7 6 3 6 3 4 3 3 5 1 9 0 11 1 5 1 2 3 9 2 1 3 2 6 2 3 3 2 3 2 2 1 2 1 7 0 10 9 9 5 5 1 7 2 5 4 5 2 3 1 1 1 1 1 1 6 0 7 4 4 1 9 3 3 7 1 1 2 1 1 2 4 5 5 3 1 3 6 1 9 0 10 5 6 7 1 4 1 2 1 2 9 3 2 3 3 1 3 2 1 1 1 7 0 10 8 5 3 5 3 3 1 8 4 4 3 1 1 1 1 3 1 1 7 0 9 2 1 2 5 5 5 8 5 5 1 3 1 2 3 1 3 5 3 4 4 2 2 3 5 1 9 0 10 7 6 1 8 7 6 7 1 5 3 2 1 1 1 3 1 1 2 2 1 9 0 7 1 6 8 1 9 9 8 3 1 1 2 1 1 2 3 2 1 5 0 11 1 9 1 2 6 8 8 5 3 1 3 1 2 1 1 2 1 5 5 2 3 3 4 1 5 0 8 9 1 6 9 5 5 4 1 1 1 1 2 3 1 9 0 8 4 6 3 2 1 5 1 2 3 1 2 2 2 2 1 3 1 1 6 0 7 6 1 2 9 9 8 5 2 2 1 3 1 3 1 5 2 5 3 4 3 5 4 3 4 1 6 0 10 1 7 1 6 9 2 1 4 9 5 1 2 2 2 1 1 1 6 0 9 4 2 9 2 6 4 2 1 9 3 2 1 1 3 3 1 6 0 7 7 1 3 3 2 6 2 3 2 3 1 2 2 1 2 5 1 3 4 1 9 0 8 5 3 3 7 1 1 5 7 2 2 3 2 1 1 1 3 2 1 9 0 10 1 7 3 3 4 8 1 4 4 2 3 3 2 3 2 2 3 1 3 1 5 0 11 5 9 1 1 2 2 5 8 9 9 1 1 1 1 2 1 2 3 1 5 3 5 1 8 0 8 4 2 9 4 9 1 2 9 3 1 1 1 2 3 2 3 1 8 0 6 6 1 2 4 1 9 1 2 3 1 3 1 1 1 1 8 0 7 3 3 1 3 1 2 6 2 2 2 3 3 2 1 2 5 4 1 1 5 3 7 1 6 0 7 5 9 1 7 2 3 8 2 1 3 1 1 2 1 5 0 9 1 9 1 7 2 9 1 9 8 2 2 1 3 2 1 5 0 6 5 9 6 1 5 7 2 1 1 1 3 3 1 5 4 1 2 2 3 4 1 8 0 7 1 1 7 7 1 2 3 3 2 1 2 3 2 1 2 1 6 0 9 5 9 1 3 5 5 1 5 3 2 1 1 2 3 2 1 7 0 11 6 6 2 2 2 4 1 7 3 4 5 1 1 3 1 1 2 1 4 2 2 2 3 3 6 5 5 5 3 5 1 8 0 9 8 1 8 2 1 1 2 1 3 2 3 1 2 2 2 3 2 1 6 0 9 2 5 1 7 8 7 3 8 1 1 1 3 2 1 2 1 6 0 7 3 1 3 9 5 2 9 1 3 1 2 1 3 5 2 2 4 2 3 4 1 8 0 11 4 2 3 1 3 2 1 4 7 3 7 3 2 3 1 2 1 1 2 1 6 0 10 9 6 9 8 2 9 1 2 1 7 3 3 1 1 1 1 1 8 0 11 1 1 1 6 1 9 9 3 9 4 9 1 3 1 1 2 1 1 1 3 1 5 4 3 4 1 6 0 9 2 4 7 1 9 7 2 7 4 3 2 1 3 1 3 1 7 0 7 2 5 6 6 1 2 7 3 3 3 1 3 1 2 1 7 0 10 7 9 6 2 8 9 6 7 2 1 1 1 3 1 1 2 1 4 2 5 5 3 5 1 8 0 11 2 1 7 5 2 1 6 1 9 5 9 1 1 2 1 2 2 3 2 1 6 0 8 8 4 8 8 1 6 9 7 3 1 3 1 1 2 1 5 0 11 4 8 4 8 5 1 2 1 7 4 1 1 1 3 1 1 1 2 2 2 2 3 5 1 5 0 7 5 1 7 8 5 8 9 3 1 3 3 1 1 5 0 11 9 6 6 4 1 5 1 1 3 2 7 3 2 3 1 2 1 9 0 10 9 8 8 1 9 4 7 9 8 8 3 3 1 1 3 1 2 2 3 3 3 4 2 5 4 7 4 4 2 5 3 3 7 1 9 0 6 7 1 1 2 5 2 1 2 3 2 3 3 2 2 2 1 6 0 11 5 1 6 1 8 6 6 1 9 3 4 1 3 1 1 1 1 1 6 0 11 1 7 3 7 9 7 3 2 1 3 5 3 1 1 1 1 3 1 4 3 1 4 1 4 3 7 1 7 0 9 3 6 5 7 1 4 3 8 3 1 3 3 2 3 1 2 1 7 0 10 3 3 1 3 4 9 5 2 2 7 2 2 3 2 1 1 2 1 5 0 8 6 1 8 2 4 4 3 5 1 1 3 1 1 1 5 4 5 2 2 1 3 5 1 6 0 9 7 1 9 6 3 5 6 9 8 1 2 2 3 3 3 1 5 0 9 3 7 3 7 9 6 1 4 4 2 3 1 3 2 1 9 0 7 8 4 5 1 1 7 8 1 2 1 2 1 1 3 3 1 5 2 3 3 1 3 5 1 8 0 9 1 6 4 9 2 9 8 8 3 2 2 3 2 1 3 1 1 1 7 0 8 1 9 5 9 7 6 6 1 2 1 1 3 2 3 1 1 7 0 9 1 5 2 2 3 7 5 1 4 1 3 3 1 3 1 2 5 3 2 1 3 3 7 1 7 0 10 1 5 8 7 2 1 3 7 1 1 3 2 1 1 2 3 1 1 5 0 10 9 1 9 2 2 1 1 8 1 5 1 1 2 1 2 1 7 0 10 3 1 1 3 1 6 5 8 4 8 1 3 1 1 3 3 2 3 3 1 4 3 4 5 3 2 7 5 3 3 6 1 9 0 11 8 3 5 1 6 3 6 7 7 7 2 3 1 2 2 1 3 1 1 2 1 7 0 9 4 6 7 2 8 1 6 3 4 3 3 1 2 2 2 1 1 7 0 9 8 5 7 1 1 3 5 2 7 2 2 1 3 1 2 1 2 3 4 3 2 1 3 5 1 8 0 6 2 1 1 3 6 1 1 1 1 3 1 1 2 3 1 7 0 6 7 1 9 2 8 1 2 1 1 3 3 3 1 1 5 0 11 6 6 6 3 3 1 2 3 3 4 3 1 1 3 3 1 1 3 4 2 3 3 5 1 9 0 11 8 1 5 3 8 4 3 6 4 4 4 3 1 2 3 3 3 1 1 3 1 8 0 9 5 2 7 4 1 8 2 7 3 2 3 3 2 1 3 2 1 1 7 0 8 4 2 1 8 1 1 8 5 3 1 3 1 2 2 2 2 5 3 1 1 3 6 1 7 0 6 5 1 2 1 4 7 1 1 2 1 1 1 1 1 6 0 6 7 4 2 9 2 1 1 2 1 3 3 2 1 8 0 7 9 7 1 4 7 1 9 1 3 2 3 1 3 2 1 3 5 4 3 1 2 3 6 1 8 0 7 6 3 3 4 1 7 7 1 3 1 1 1 3 3 1 1 9 0 6 1 2 2 6 4 9 1 3 2 1 3 1 3 3 1 1 8 0 8 9 1 2 5 2 6 9 5 1 1 1 2 2 1 1 3 1 3 3 3 4 5 2 5 3 4 3 3 5 1 6 0 9 2 9 9 1 4 2 3 9 3 1 2 3 3 2 1 1 5 0 7 5 2 3 1 8 3 8 1 1 3 1 1 1 7 0 9 3 8 1 5 5 4 1 2 9 1 1 1 1 3 1 2 5 2 3 2 4 3 5 1 7 0 11 9 1 5 7 1 3 7 1 7 4 6 1 1 1 1 1 2 2 1 9 0 8 7 4 7 7 6 1 2 9 1 2 2 1 2 1 3 3 1 1 9 0 7 9 5 1 1 3 6 3 3 2 1 2 2 3 1 2 2 4 2 3 1 2 3 5 1 5 0 10 1 9 4 3 5 7 8 4 2 6 1 1 3 3 3 1 7 0 8 5 1 1 2 2 1 4 4 3 1 3 1 2 1 3 1 7 0 6 7 1 3 4 6 5 3 1 3 2 1 1 2 1 1 3 4 5 3 4 1 9 0 7 1 4 7 8 5 2 4 2 1 1 2 2 3 2 3 3 1 7 0 6 6 4 8 3 7 1 1 1 1 2 3 2 2 1 5 0 9 7 3 6 7 1 7 7 2 9 2 1 3 3 1 1 4 5 1 6 6 1 7 8 6 7 3 4 3 3 6 1 5 0 11 2 1 2 8 5 3 1 2 6 4 8 1 3 2 1 1 1 5 0 7 3 5 1 8 2 6 4 1 2 1 2 1 1 5 0 9 7 1 7 1 9 4 5 6 3 3 1 1 2 3 4 5 3 3 2 5 3 6 1 8 0 8 1 1 1 7 4 6 4 4 2 1 1 2 1 2 3 1 1 7 0 6 1 4 2 9 4 3 1 1 1 2 1 1 3 1 9 0 9 5 2 7 1 6 2 9 7 8 3 3 3 1 3 3 1 1 1 2 5 2 4 2 3 3 7 1 9 0 6 7 5 6 1 8 9 1 2 3 1 3 1 1 1 1 1 6 0 6 7 4 2 1 4 3 3 3 3 1 2 1 1 7 0 7 1 3 4 1 9 6 2 2 3 1 3 1 2 3 2 3 5 5 4 3 2 3 5 1 7 0 10 5 2 3 1 9 3 5 6 3 9 3 1 2 1 1 2 3 1 5 0 11 7 3 9 2 3 4 8 1 1 8 5 1 2 3 1 1 1 7 0 8 3 1 7 9 1 1 9 1 1 2 1 2 2 2 1 1 3 5 5 3 2 4 3 5 4 3 7 1 6 0 10 1 7 4 5 1 6 3 6 7 9 1 3 1 1 3 3 1 6 0 6 1 4 3 1 2 8 1 3 2 1 1 1 1 9 0 6 7 1 8 2 3 7 3 3 1 3 3 1 1 1 3 5 3 3 5 2 3 1 3 7 1 6 0 6 9 3 4 1 4 1 2 3 1 1 1 2 1 5 0 8 2 7 5 6 6 9 2 1 1 1 1 2 3 1 6 0 9 6 2 7 6 2 7 7 1 2 3 3 1 2 3 3 2 5 2 1 4 5 4 3 4 1 8 0 10 9 1 1 2 7 6 1 6 2 1 2 1 1 3 2 3 3 2 1 9 0 9 5 8 8 6 7 3 6 7 1 3 3 3 3 1 3 3 1 1 1 5 0 9 6 1 1 2 9 1 8 6 9 1 2 1 3 1 3 3 3 3 3 5 1 9 0 10 8 8 5 4 4 4 2 1 1 4 1 1 1 2 1 2 3 2 2 1 8 0 6 5 4 1 1 1 7 3 1 3 3 1 1 1 3 1 9 0 11 4 7 7 5 5 6 8 8 1 1 6 2 1 2 1 1 1 2 3 2 3 4 2 4 5 3 5 1 9 0 7 2 7 9 1 8 7 9 1 2 2 1 1 3 3 1 2 1 5 0 8 4 5 3 1 6 5 2 4 1 1 1 1 1 1 6 0 8 1 8 4 1 3 9 7 5 2 3 3 1 1 1 4 1 2 1 5 2 5 3 5 5 3 3 7 1 5 0 6 9 6 4 9 1 2 1 1 2 1 3 1 5 0 9 1 7 8 5 4 8 1 8 8 1 2 2 1 1 1 7 0 9 5 1 2 7 5 2 8 4 1 2 1 3 3 3 3 2 3 4 1 2 1 1 4 3 6 1 7 0 8 8 5 5 1 4 9 2 6 2 1 3 3 2 1 3 1 5 0 10 4 6 1 6 5 5 2 5 1 5 1 1 2 3 2 1 9 0 9 5 1 2 2 2 2 6 5 3 1 1 2 2 3 3 1 2 2 4 2 2 3 1 2 3 5 1 8 0 11 6 5 5 1 4 3 7 4 7 6 3 2 1 3 2 2 3 1 3 1 6 0 6 1 9 6 6 7 6 2 1 1 2 2 1 1 5 0 9 1 1 6 2 3 5 2 6 8 1 2 3 1 1 2 1 5 3 1 3 5 1 9 0 10 2 4 1 7 9 6 4 6 9 8 3 3 2 1 2 1 3 1 2 1 7 0 6 6 1 3 2 1 7 1 3 2 1 1 2 3 1 6 0 10 7 7 6 9 9 2 3 2 9 1 1 3 1 2 3 1 3 5 1 1 5 3 4 1 8 0 10 3 1 1 9 1 1 3 7 6 6 3 1 2 2 1 2 3 3 1 6 0 8 3 5 9 2 1 1 1 1 1 1 2 2 2 2 1 7 0 9 6 4 4 8 1 8 1 8 4 3 1 1 2 2 1 1 4 1 1 2 4 6 7 4 4 3 7 1 5 0 9 4 1 3 2 9 1 8 2 8 2 1 1 1 2 1 5 0 8 7 7 1 8 8 9 8 2 2 1 1 3 2 1 8 0 11 5 5 1 1 1 3 6 6 3 6 9 1 1 2 2 3 1 2 1 4 5 3 1 2 4 3 3 4 1 9 0 6 1 8 3 2 5 2 1 3 3 2 2 3 1 1 2 1 5 0 10 1 6 2 9 1 5 9 2 8 7 2 1 1 3 2 1 8 0 6 2 9 3 1 3 1 1 1 1 3 1 2 1 2 2 5 2 1 3 6 1 6 0 6 1 8 1 2 5 3 1 3 1 1 1 1 1 5 0 7 7 8 5 7 7 9 1 1 1 3 2 1 1 7 0 6 7 8 9 1 3 1 1 1 3 3 3 3 2 1 2 1 5 1 3 3 5 1 5 0 10 5 4 1 5 6 1 7 6 4 1 1 2 1 2 1 1 5 0 7 4 1 7 1 5 3 9 3 2 1 2 1 1 9 0 9 4 4 9 5 5 1 1 9 7 2 3 2 1 1 2 1 3 3 4 1 3 3 2 4 4 4 2 5 3 3 6 1 9 0 8 1 5 3 5 3 4 6 1 2 1 3 2 3 1 2 1 1 1 9 0 11 3 8 4 8 2 2 3 3 1 1 1 1 2 3 1 1 3 3 2 1 1 5 0 9 1 8 1 5 9 3 4 8 2 3 3 1 1 2 2 4 1 2 3 5 3 4 1 6 0 6 9 2 8 1 8 5 3 1 3 1 1 3 1 8 0 10 8 1 6 7 8 8 8 3 4 1 3 1 2 2 3 1 3 3 1 9 0 11 2 3 3 4 9 6 1 4 5 8 1 3 1 2 3 2 2 3 3 3 3 1 5 5 3 5 1 9 0 10 1 1 9 7 4 6 7 5 6 9 1 3 1 1 3 1 3 1 1 1 5 0 10 7 7 1 1 9 4 1 5 4 9 2 2 1 1 1 1 7 0 11 9 4 1 1 4 9 7 7 8 2 1 3 1 1 2 3 3 1 3 2 3 3 4 3 5 1 7 0 10 9 6 7 1 1 5 6 8 6 8 2 1 3 3 3 2 3 1 7 0 7 5 2 4 4 8 1 1 3 3 3 3 2 1 3 1 5 0 6 1 1 5 6 5 1 2 1 3 2 1 3 1 3 2 3 3 4 1 9 0 7 3 8 9 6 6 7 1 1 2 1 2 1 2 2 1 2 1 9 0 6 1 3 8 1 8 4 3 3 1 2 2 2 3 1 2 1 6 0 6 2 2 5 7 1 3 2 1 1 3 1 1 5 5 3 3 4 5 1 4 4 3 6 1 6 0 8 4 1 3 6 6 1 2 1 1 3 3 3 3 3 1 5 0 7 5 8 1 7 6 7 4 1 1 3 1 2 1 7 0 6 4 5 8 8 1 9 1 3 1 2 1 1 1 2 1 3 4 4 4 3 5 1 6 0 6 1 9 1 1 9 4 3 2 1 3 1 2 1 9 0 8 4 1 2 8 5 3 9 8 3 3 1 2 3 2 3 1 1 1 6 0 9 6 7 4 3 8 3 1 1 9 2 3 1 1 1 2 1 4 1 4 2 3 4 1 8 0 11 1 1 2 4 9 6 3 6 7 4 1 3 2 1 1 1 1 1 3 1 6 0 8 8 7 8 9 6 2 4 1 3 2 1 1 3 2 1 9 0 8 2 3 1 1 1 7 3 5 2 1 2 2 2 1 2 2 3 4 2 3 1 3 6 1 7 0 10 1 1 3 2 1 8 2 4 8 5 1 1 2 2 3 2 1 1 7 0 6 1 9 5 4 9 7 2 1 3 3 2 1 1 1 8 0 9 6 6 5 2 1 5 7 1 2 3 1 1 2 1 1 2 2 2 5 2 3 3 1 4 2 3 4 4 3 3 7 1 8 0 11 1 5 4 3 8 5 2 8 1 9 4 1 2 3 2 1 1 3 1 1 9 0 8 8 8 8 9 5 1 1 2 2 2 1 2 1 3 2 1 1 1 9 0 7 9 8 3 1 2 2 9 1 1 1 3 1 3 2 2 2 4 2 5 5 2 3 4 3 6 1 6 0 9 1 5 7 6 2 6 6 1 8 1 2 3 2 1 2 1 6 0 6 9 4 1 2 2 6 3 2 3 1 3 2 1 7 0 8 1 5 1 5 9 6 9 2 3 2 2 2 1 2 2 4 3 1 1 3 1 3 7 1 9 0 9 5 6 9 1 5 4 6 2 1 3 2 1 1 2 3 2 1 1 1 6 0 10 1 1 8 1 9 1 8 4 5 2 2 3 1 1 1 3 1 7 0 9 6 8 3 8 3 4 3 1 5 3 3 1 2 3 1 1 4 1 1 2 3 1 1 3 5 1 5 0 10 9 5 8 3 3 9 6 1 1 3 3 3 1 3 1 1 9 0 8 5 3 2 6 1 1 1 7 3 2 2 1 3 3 2 2 1 1 9 0 10 7 7 1 2 6 5 7 9 2 7 3 3 1 2 2 2 1 2 1 4 5 5 1 4 1 6 3 4 4 8 7 2 5 4 3 4 1 6 0 11 5 7 1 1 8 7 2 4 3 7 4 1 2 2 1 1 3 1 6 0 9 1 3 5 5 8 1 4 9 1 2 2 1 1 1 2 1 7 0 9 1 4 8 6 8 2 1 3 5 1 2 1 3 2 3 1 1 4 4 2 3 6 1 7 0 9 5 6 1 6 6 6 6 8 1 3 3 1 1 1 3 1 1 6 0 11 3 5 7 6 9 9 3 6 1 6 8 1 1 3 3 2 1 1 8 0 10 2 9 2 7 1 5 1 7 9 1 3 1 2 2 1 1 2 2 3 4 5 3 5 3 3 5 1 9 0 7 2 5 9 1 3 1 3 1 1 1 3 2 2 2 2 2 1 9 0 7 1 8 2 3 4 7 8 1 2 3 1 3 2 1 3 2 1 8 0 11 1 1 1 9 6 4 2 8 5 4 5 2 1 2 3 3 2 1 1 5 3 3 2 2 3 7 1 6 0 9 1 3 7 9 5 4 2 3 7 1 2 2 1 1 3 1 7 0 7 3 6 5 2 4 7 1 1 1 1 2 3 1 1 1 9 0 6 4 1 6 2 9 9 1 2 2 1 2 3 1 1 1 3 2 3 3 4 5 3 3 4 1 9 0 10 4 1 1 5 1 8 7 9 4 6 2 1 3 1 2 1 2 2 3 1 8 0 6 4 5 1 4 7 1 3 2 1 1 1 3 1 1 1 6 0 11 4 7 3 3 7 4 1 6 4 3 1 2 1 1 2 1 3 3 3 5 1 3 7 1 4 4 4 3 6 1 6 0 7 5 5 8 4 5 1 8 2 3 3 3 1 3 1 5 0 8 8 1 3 5 7 1 6 5 1 3 2 3 3 1 8 0 6 3 1 2 4 2 1 2 1 1 1 3 1 1 1 1 3 4 1 3 5 3 7 1 7 0 8 7 6 3 5 1 9 7 2 2 1 2 1 1 3 1 1 5 0 6 4 2 4 3 1 1 2 1 1 2 3 1 7 0 11 8 6 2 3 5 9 8 9 1 9 8 1 1 1 2 2 2 2 2 4 5 1 3 2 5 3 6 1 5 0 6 8 1 1 1 5 2 2 3 2 1 1 1 5 0 7 6 2 7 6 2 1 8 3 3 1 1 2 1 6 0 6 8 4 6 1 1 8 1 2 1 1 3 3 5 2 3 1 5 4 3 4 1 6 0 7 3 7 5 7 1 7 7 2 3 2 1 1 1 1 7 0 10 3 1 7 7 8 3 7 1 9 7 1 3 3 3 1 1 1 1 8 0 7 1 8 7 1 1 2 4 2 3 1 3 1 1 1 2 3 3 2 1 2 2 6 4 5 4 3 4 1 9 0 6 5 4 1 1 9 8 1 1 3 1 1 3 1 2 3 1 5 0 10 8 8 4 1 8 8 1 9 1 4 2 1 2 1 2 1 5 0 8 4 1 1 3 1 1 4 3 3 1 2 1 3 3 5 1 3 3 5 1 9 0 10 3 4 9 5 1 5 7 1 4 2 1 1 1 1 2 1 3 2 1 1 7 0 10 5 2 7 1 2 7 1 2 9 1 3 1 1 1 3 1 1 1 9 0 6 6 7 6 5 1 8 1 1 1 1 3 1 3 1 2 1 3 3 2 5 3 4 1 8 0 11 7 7 8 3 3 7 1 7 5 3 3 1 2 3 1 1 1 1 2 1 9 0 10 1 9 5 4 2 5 3 9 1 2 2 3 3 2 2 3 1 1 1 1 6 0 6 5 9 4 3 1 8 2 1 2 1 1 3 3 3 4 5 3 6 1 9 0 9 2 4 1 6 4 2 9 6 4 2 2 2 1 3 2 1 1 3 1 8 0 7 1 8 5 6 1 8 1 3 2 1 3 3 2 2 1 1 5 0 9 6 9 7 8 5 7 6 8 1 1 3 1 1 1 1 2 4 4 1 2 3 7 1 5 0 11 1 3 7 4 6 9 4 7 1 1 7 1 2 2 3 3 1 7 0 7 9 8 3 9 5 5 1 3 3 3 1 1 2 1 1 5 0 8 1 2 3 6 2 3 5 3 1 2 1 1 1 4 1 1 4 4 1 5 3 1 3 1 5 3 3 7 1 5 0 7 3 1 2 3 2 8 6 2 1 1 1 2 1 6 0 7 9 1 7 2 1 4 7 2 2 1 3 3 3 1 7 0 8 5 8 3 7 4 1 8 5 2 3 1 1 3 3 1 5 3 2 2 5 5 1 3 5 1 6 0 8 9 5 1 3 3 9 5 8 2 2 2 1 2 2 1 5 0 6 6 2 9 1 6 3 3 3 2 3 1 1 6 0 10 7 5 3 7 4 7 9 1 5 9 1 1 1 1 2 2 2 1 5 4 1 3 6 1 6 0 9 1 3 8 9 9 4 9 3 3 2 2 1 2 3 1 1 6 0 11 8 4 2 1 4 7 5 9 6 8 1 1 1 3 1 1 1 1 5 0 7 5 2 5 3 4 7 1 1 1 2 1 3 5 3 1 5 4 5 3 4 1 6 0 6 1 2 2 1 8 1 1 1 3 2 3 1 1 9 0 9 9 5 4 2 2 5 9 8 1 3 3 1 1 2 3 3 1 3 1 9 0 11 1 2 4 4 2 7 1 5 4 2 2 2 1 3 1 3 3 2 2 1 5 2 4 2 3 7 1 7 0 10 7 3 5 1 6 9 1 2 9 8 1 1 3 1 3 1 1 1 9 0 9 3 1 1 7 3 1 2 7 7 1 2 2 1 2 2 2 3 3 1 9 0 9 8 2 1 1 1 2 1 3 8 1 1 2 3 1 2 1 3 1 1 4 1 5 5 3 1 7 3 3 4 5 3 7 1 9 0 6 3 5 1 3 1 4 2 3 1 2 2 2 2 2 2 1 8 0 9 8 8 1 2 9 1 4 7 6 3 1 3 2 2 1 2 2 1 6 0 9 1 1 4 2 8 5 6 7 7 1 2 1 2 2 3 2 4 1 1 1 2 5 3 7 1 9 0 8 1 1 9 4 9 7 5 8 1 1 1 3 3 1 1 3 2 1 7 0 9 9 1 5 8 4 4 7 3 3 3 3 3 1 3 3 2 1 8 0 6 2 1 9 1 9 7 2 2 2 1 1 3 2 1 5 5 2 4 1 5 3 3 7 1 8 0 11 1 1 9 7 2 5 8 3 1 6 3 1 2 1 3 1 2 1 1 1 6 0 11 3 4 5 6 1 4 6 6 2 3 3 1 2 1 2 1 2 1 8 0 6 5 7 9 1 1 8 3 1 3 2 2 1 3 1 2 2 2 1 1 1 2 3 4 1 8 0 11 8 4 4 3 9 7 4 8 1 6 3 1 1 3 1 3 1 3 1 1 5 0 10 3 1 9 2 8 6 8 2 7 2 1 2 2 1 1 1 7 0 10 7 1 2 2 4 7 5 1 1 4 2 3 2 1 3 3 1 3 4 2 2 5 4 2 1 1 5 3 3 5 1 6 0 7 2 9 5 7 3 1 9 1 1 3 1 1 3 1 9 0 6 2 9 2 9 6 1 2 1 1 3 2 2 3 2 3 1 7 0 6 9 6 4 1 1 2 1 3 2 1 3 1 1 3 2 5 5 1 3 5 1 7 0 7 7 7 1 1 1 5 5 1 1 3 1 3 1 3 1 6 0 11 2 8 6 1 9 2 1 3 4 1 6 3 2 1 3 2 2 1 7 0 9 9 9 7 9 3 2 8 1 5 3 2 3 1 1 3 1 4 3 1 1 1 3 4 1 8 0 8 1 9 9 4 1 8 3 8 1 1 1 1 2 1 1 1 1 6 0 9 9 4 4 1 2 3 5 9 1 2 1 2 3 3 1 1 6 0 10 1 8 7 4 9 9 3 7 2 1 3 2 2 2 1 2 2 2 1 2 3 4 1 7 0 8 5 3 7 5 4 6 3 1 3 1 1 3 3 1 3 1 7 0 7 4 1 5 2 4 7 8 1 3 1 2 1 1 3 1 5 0 8 8 3 7 7 4 1 9 6 2 2 1 2 1 2 2 5 1 3 6 1 6 0 10 6 9 5 3 7 7 1 3 1 1 2 2 2 1 1 1 1 9 0 8 1 2 5 6 3 2 1 8 1 1 3 3 1 2 1 2 1 1 6 0 11 4 1 1 1 2 5 9 8 6 5 5 2 1 1 1 3 3 4 1 3 3 5 2 3 4 4 4 5 3 5 1 8 0 7 1 1 5 6 1 4 3 2 1 3 1 3 1 1 2 1 7 0 6 2 7 7 1 8 1 1 3 1 1 1 1 2 1 7 0 7 5 1 6 8 7 2 5 3 1 2 2 2 1 3 3 2 3 2 5 3 7 1 8 0 9 1 8 4 1 6 3 2 1 3 1 1 3 3 1 2 1 3 1 7 0 9 2 5 1 8 9 4 2 4 5 1 3 3 1 1 1 2 1 6 0 11 8 2 1 3 1 5 1 9 8 2 2 1 1 3 1 2 2 3 4 3 3 3 1 2 3 7 1 6 0 8 4 9 4 5 2 1 1 1 1 3 2 3 1 3 1 6 0 6 1 6 6 9 7 2 3 3 1 3 1 3 1 7 0 6 7 4 8 7 1 5 1 3 2 3 2 1 2 2 4 3 3 5 2 2 3 5 1 8 0 11 4 5 1 9 9 8 3 2 7 7 7 3 1 1 1 1 2 3 1 1 6 0 10 5 4 9 4 8 6 1 5 5 2 3 2 2 1 3 2 1 9 0 10 6 7 9 2 2 7 8 2 6 1 2 1 2 3 3 3 1 3 1 5 3 2 2 4 1 2 3 4 3 6 1 7 2 4 5 3 6 1 9 0 7 7 9 1 2 8 3 3 2 1 2 1 3 2 1 2 1 1 7 0 11 4 9 1 1 4 5 7 9 4 5 8 3 1 3 1 3 1 3 1 5 0 7 2 8 1 6 8 1 2 3 3 1 2 1 5 2 5 2 5 2 3 4 1 5 0 9 1 9 3 1 3 6 3 5 1 1 1 3 3 2 1 5 0 8 7 7 3 1 3 5 3 4 1 3 2 2 1 1 8 0 6 3 9 3 1 6 2 3 1 3 1 1 1 2 1 3 2 2 2 3 4 1 5 0 11 7 5 7 2 9 3 8 1 3 2 8 2 3 2 2 1 1 6 0 10 7 6 6 2 4 8 7 1 1 9 1 2 3 1 3 3 1 7 0 10 4 2 9 6 1 7 4 8 2 1 3 2 1 1 3 1 3 1 1 5 2 3 7 1 7 0 8 9 3 9 1 4 3 1 5 3 1 1 1 1 2 3 1 7 0 11 6 7 1 1 7 6 7 6 8 8 8 2 1 2 1 1 3 1 1 7 0 7 5 7 1 1 1 1 5 1 2 1 3 1 3 3 5 3 5 3 4 2 2 2 1 3 2 5 5 3 3 7 1 8 0 6 6 1 1 1 6 3 2 1 2 1 3 1 2 1 1 5 0 11 1 3 6 4 7 2 4 8 7 5 1 1 2 1 2 1 1 5 0 10 1 7 6 4 5 1 2 8 4 4 2 1 2 2 3 4 4 5 4 5 3 3 3 6 1 7 0 11 2 2 8 7 1 2 7 8 4 1 9 1 1 2 2 3 1 2 1 7 0 11 6 3 8 1 4 2 2 5 9 7 8 2 1 3 2 3 3 3 1 9 0 9 7 6 4 1 2 1 7 1 3 1 2 2 3 1 3 1 1 3 1 2 4 2 3 3 3 6 1 8 0 7 8 1 3 4 5 8 9 3 3 2 1 3 1 2 2 1 6 0 11 7 3 6 9 1 4 2 9 4 3 4 3 2 2 3 1 1 1 9 0 8 4 6 1 5 8 2 1 4 1 2 1 2 1 3 1 1 1 3 5 1 2 3 1 3 7 1 5 0 8 5 6 6 2 1 7 4 1 1 2 1 1 3 1 6 0 11 9 1 1 3 1 5 5 5 7 7 5 2 1 1 3 2 2 1 6 0 8 6 6 4 5 7 2 1 2 1 2 1 1 3 2 4 1 5 1 3 5 3 3 7 1 6 0 10 1 9 1 3 2 5 9 1 6 8 1 1 3 1 1 1 1 9 0 8 1 3 2 2 5 4 4 4 3 2 1 1 1 1 1 1 1 1 7 0 8 6 6 2 3 5 5 7 1 1 2 1 2 2 1 1 5 2 5 2 1 1 5 4 5 7 5 3 3 6 1 8 0 6 3 8 1 6 5 3 1 2 1 2 3 3 1 3 1 6 0 10 4 9 5 4 6 8 3 1 4 7 1 1 1 1 2 3 1 7 0 10 5 2 6 7 7 1 7 7 6 7 3 1 3 1 2 3 2 5 2 4 1 4 3 3 6 1 8 0 7 7 9 7 1 8 8 1 2 1 2 1 3 1 2 2 1 5 0 9 2 1 4 7 6 1 9 2 6 3 1 2 3 1 1 8 0 6 4 1 1 3 7 8 2 3 3 2 3 1 1 3 1 4 5 5 3 1 3 5 1 5 0 9 9 8 8 7 2 1 6 9 8 1 1 2 2 2 1 5 0 9 8 4 5 4 5 7 2 1 7 2 3 2 1 1 1 9 0 7 7 6 9 1 5 9 7 3 3 1 1 2 1 2 2 2 3 1 3 5 4 3 6 1 6 0 10 9 4 2 5 2 4 1 4 1 5 3 1 1 3 1 1 1 8 0 9 8 7 1 8 7 5 7 4 6 3 3 1 1 3 3 1 2 1 6 0 8 8 8 9 1 9 1 4 1 1 3 2 1 1 3 2 1 2 4 3 4 3 5 1 6 0 8 9 5 1 4 9 6 2 1 2 2 1 3 1 1 1 7 0 6 5 9 4 1 5 8 3 1 3 1 1 3 3 1 7 0 11 5 8 2 5 1 9 7 9 1 2 8 1 2 2 1 1 2 2 1 1 2 1 2 1 3 3 5 4 3 7 1 9 0 7 6 4 9 1 9 1 3 1 2 3 1 2 3 1 2 1 1 9 0 8 1 6 5 8 6 9 2 1 3 3 3 2 1 1 2 1 1 1 9 0 11 1 3 4 6 1 9 5 4 5 1 7 1 1 3 3 3 3 1 3 1 5 3 4 5 5 1 5 3 7 1 6 0 8 4 1 6 5 9 7 6 4 2 2 1 2 1 1 1 9 0 9 1 7 5 1 2 9 3 7 6 1 2 3 2 1 1 3 3 2 1 8 0 8 5 2 7 1 8 8 5 4 2 3 2 1 2 1 1 1 3 5 1 1 3 4 2 3 4 1 6 0 8 2 5 2 7 8 1 4 5 1 2 1 2 2 1 1 7 0 8 7 1 6 2 4 5 5 2 3 1 2 1 3 1 3 1 5 0 11 5 7 1 3 3 9 1 6 1 7 5 3 1 3 2 3 5 3 1 5 3 6 1 8 0 8 7 5 4 1 9 4 5 7 1 1 2 3 3 3 1 3 1 7 0 11 2 3 7 8 2 5 2 1 1 1 2 1 2 1 1 3 2 1 1 5 0 11 2 1 5 4 3 3 7 9 2 7 1 2 2 2 3 1 2 1 2 5 2 2 3 4 1 7 0 7 8 3 5 9 3 6 1 1 3 3 1 1 3 1 1 5 0 10 9 9 3 7 1 5 2 8 7 9 1 3 3 3 2 1 5 0 8 7 1 1 7 4 6 5 1 1 3 2 3 3 2 5 5 2 4 4 2 7 5 3 3 4 1 5 0 9 7 3 1 6 2 9 1 1 3 2 3 1 1 3 1 6 0 6 5 4 7 8 1 7 1 3 3 3 3 1 1 8 0 10 7 9 3 1 6 5 6 7 7 6 1 3 3 3 1 2 1 3 3 4 5 1 3 4 1 7 0 10 9 1 5 7 8 6 9 1 5 1 2 3 1 2 2 3 1 1 6 0 8 9 3 1 2 2 9 9 7 2 1 1 1 3 2 1 9 0 10 1 5 1 5 1 5 7 3 6 2 1 3 1 1 3 1 3 3 2 2 3 5 1 3 6 1 9 0 10 7 8 8 1 1 4 3 7 4 8 2 1 3 3 3 1 3 3 1 1 8 0 7 9 1 1 5 2 3 7 1 3 1 3 2 2 2 2 1 8 0 9 5 7 5 4 5 2 7 7 1 1 1 1 3 2 1 1 3 2 1 4 2 1 3 3 6 1 6 0 9 3 7 6 2 4 7 8 1 6 2 1 2 2 1 3 1 7 0 8 8 8 9 1 4 1 2 6 3 1 1 3 3 3 1 1 9 0 11 4 7 1 4 8 1 1 1 6 5 8 2 2 1 3 1 1 1 2 1 1 5 1 1 3 2 3 6 1 9 0 6 7 1 3 5 2 3 3 2 1 1 1 1 1 2 2 1 9 0 6 1 1 6 8 8 6 2 2 2 1 2 1 2 3 2 1 9 0 9 4 2 1 1 7 2 3 4 9 3 2 1 1 1 3 2 1 2 4 4 4 2 1 1 4 4 4 5 5 3 6 1 6 0 6 9 1 2 7 1 7 3 2 1 1 1 3 1 6 0 6 1 4 5 2 6 3 2 1 1 1 2 3 1 6 0 10 1 4 8 1 1 5 9 5 4 7 3 1 2 2 1 3 4 1 5 2 2 3 3 4 1 8 0 9 5 2 6 3 6 5 1 5 1 2 1 2 1 1 3 1 1 1 8 0 7 2 4 1 1 7 3 4 1 2 1 1 1 2 3 1 1 8 0 6 2 3 1 5 6 4 1 1 2 1 2 2 3 2 2 2 2 3 3 6 1 5 0 9 4 2 9 1 8 1 8 1 9 1 1 1 2 3 1 9 0 8 1 3 1 7 8 6 2 1 3 1 2 2 1 3 1 3 3 1 9 0 10 6 2 1 1 2 9 1 3 4 7 3 3 3 1 1 3 1 2 3 1 3 2 5 1 2 3 5 1 5 0 9 1 1 1 6 1 8 9 1 8 3 1 2 2 1 1 5 0 8 8 4 8 1 1 4 2 2 3 3 1 1 2 1 6 0 10 9 8 1 5 1 1 5 1 8 5 1 3 1 2 3 1 1 5 3 1 5 3 7 1 7 0 10 1 2 3 1 7 7 5 5 6 6 2 2 3 3 3 2 1 1 5 0 7 9 1 4 4 1 7 5 2 2 3 2 1 1 8 0 8 6 3 1 2 2 3 2 7 2 1 1 2 3 3 3 2 3 1 2 3 2 2 5 4 7 4 1 4 4 4 3 5 1 8 0 10 4 2 1 9 3 1 4 2 6 8 1 1 1 2 1 1 3 3 1 6 0 9 9 2 2 6 1 1 6 3 3 1 1 1 3 3 3 1 5 0 7 2 7 9 1 8 7 9 2 3 1 3 1 1 2 4 1 4 3 5 1 7 0 6 2 3 2 2 9 1 3 3 2 3 1 3 2 1 6 0 10 8 9 1 9 3 9 5 4 1 1 3 2 1 3 2 1 1 6 0 6 5 1 4 1 2 6 2 3 1 2 3 2 5 1 5 1 1 3 5 1 8 0 9 1 8 6 2 4 8 4 2 7 1 3 3 1 1 2 2 2 1 8 0 9 1 5 9 5 8 7 6 4 9 1 3 1 1 3 3 2 1 1 5 0 11 2 8 1 7 2 9 6 4 1 9 7 1 2 3 1 3 3 1 3 5 1 3 4 1 7 0 11 4 2 6 8 6 8 5 1 9 9 1 3 2 1 1 1 3 1 1 9 0 9 1 3 6 1 5 2 1 8 2 2 2 1 1 1 3 2 3 2 1 8 0 6 7 5 6 1 9 9 1 1 1 3 1 1 2 2 4 3 1 4 3 1 4 6 3 2 7 3 5 4 3 6 1 8 0 11 3 2 9 9 1 6 1 9 3 2 1 1 3 3 2 1 1 1 3 1 7 0 6 3 2 3 4 1 2 2 1 1 3 3 1 3 1 8 0 7 1 7 8 1 1 7 9 2 1 3 3 3 2 1 1 5 2 3 3 1 2 3 6 1 7 0 8 1 1 8 4 9 3 4 9 1 1 1 3 3 2 1 1 8 0 9 1 1 4 8 9 7 1 8 9 2 1 1 1 1 1 3 2 1 8 0 10 3 2 5 8 9 8 3 8 1 5 1 2 3 1 1 3 2 2 5 2 3 1 4 4 3 6 1 6 0 10 7 1 3 4 8 3 2 1 4 5 3 3 2 2 1 1 1 8 0 11 7 1 5 2 4 5 4 8 1 9 9 3 2 1 3 2 3 1 1 1 7 0 6 1 2 9 5 2 4 3 1 1 1 3 3 3 1 5 4 2 2 2 3 5 1 5 0 7 1 1 2 4 3 7 8 3 1 3 1 1 1 8 0 7 8 2 8 8 1 6 2 2 1 1 2 2 1 2 2 1 7 0 9 6 4 3 1 5 5 1 8 4 3 2 1 3 1 2 2 3 1 2 1 1 3 4 1 6 0 11 1 1 6 1 4 6 5 1 5 2 2 2 3 1 2 1 3 1 9 0 7 5 4 4 6 5 1 7 2 2 2 2 1 1 1 1 2 1 7 0 6 8 1 4 6 6 2 3 1 2 2 1 2 2 3 5 5 3 2 5 4 7 5 3 3 6 1 5 0 9 8 7 8 1 6 4 8 9 8 3 3 1 3 2 1 8 0 11 8 9 7 2 5 1 1 8 1 3 6 3 2 1 2 1 2 1 1 1 6 0 7 1 6 2 1 9 7 4 3 3 2 2 1 1 3 4 2 1 5 4 3 5 1 5 0 7 2 1 9 7 6 1 6 1 3 2 2 2 1 9 0 11 9 3 5 5 9 3 1 3 3 2 2 2 1 1 2 3 1 2 2 1 1 6 0 6 4 4 5 2 1 1 2 2 1 3 2 3 4 5 2 1 4 3 5 1 5 0 10 9 2 1 6 9 2 2 1 6 9 2 1 1 1 1 1 7 0 8 1 3 8 3 2 1 2 7 3 3 1 1 3 1 1 1 8 0 6 5 5 1 9 4 5 1 3 2 1 2 3 2 2 2 5 4 1 1 3 5 1 6 0 6 1 1 6 9 8 3 1 3 2 1 2 2 1 9 0 6 1 7 3 6 7 3 2 2 2 3 1 3 2 2 3 1 9 0 7 6 2 7 1 1 3 1 1 3 2 3 2 1 1 1 2 5 2 1 1 4 3 7 1 7 0 7 7 1 2 3 5 9 1 2 2 2 3 1 1 1 1 5 0 10 5 2 4 9 1 3 8 1 6 9 3 1 1 2 2 1 6 0 11 6 7 8 4 6 8 1 8 1 9 2 1 1 1 3 1 3 3 3 3 1 4 4 4 3 3 1 5 5 3 6 1 6 0 11 8 8 9 7 3 4 3 1 5 6 7 2 3 3 1 1 2 1 9 0 10 2 2 2 6 1 6 9 5 5 1 1 3 3 2 1 3 3 3 1 1 7 0 7 7 7 3 1 3 3 7 1 1 1 2 2 3 2 3 2 2 1 3 2 3 7 1 6 0 10 1 3 7 8 8 8 6 1 7 4 1 3 2 3 1 1 1 9 0 10 4 1 6 1 6 1 5 9 3 6 1 3 3 2 1 3 3 2 2 1 9 0 9 2 8 1 2 4 4 5 6 6 2 2 3 1 2 3 2 1 3 4 2 5 3 5 4 5 3 4 1 7 0 6 8 1 4 1 1 3 3 1 1 2 1 2 1 1 5 0 11 6 3 3 1 9 9 3 2 3 6 1 3 2 1 2 2 1 6 0 10 2 6 9 3 5 1 5 5 4 1 2 1 2 3 2 3 1 5 2 5 3 6 1 7 0 11 3 1 9 2 5 4 3 7 8 7 8 2 1 1 2 3 2 1 1 5 0 7 9 2 7 7 1 2 7 2 2 2 1 3 1 6 0 11 1 5 1 9 9 4 8 5 8 8 8 2 1 3 3 2 3 3 2 3 1 3 2 3 4 1 8 0 9 1 7 1 3 7 6 6 1 2 1 3 2 1 3 3 3 1 1 5 0 6 4 4 8 8 7 1 2 2 1 1 1 1 5 0 7 7 4 5 7 9 9 1 1 2 1 3 2 5 1 3 5 2 6 3 7 2 4 5 3 6 1 6 0 7 1 3 1 8 3 4 8 2 1 2 3 2 2 1 6 0 9 8 9 6 6 2 7 1 9 1 1 3 3 3 2 1 1 5 0 7 3 9 6 1 3 2 5 1 2 1 2 2 3 1 2 3 5 1 3 6 1 6 0 8 2 8 4 2 7 1 5 3 1 2 1 1 2 3 1 9 0 10 9 1 8 8 8 2 4 5 5 5 1 3 2 1 1 2 3 1 3 1 6 0 6 5 7 9 5 1 1 3 2 1 2 3 3 2 2 1 1 5 1 3 5 1 9 0 9 9 1 3 5 3 6 4 3 6 2 2 2 2 1 1 1 1 3 1 7 0 9 6 1 8 7 4 2 1 6 6 2 3 1 3 3 3 3 1 7 0 10 4 7 2 4 2 2 6 4 1 5 1 1 2 2 2 2 3 3 1 2 2 3 3 4 1 9 0 10 6 9 1 2 1 3 5 5 3 2 1 2 1 3 1 1 1 1 1 1 9 0 9 1 7 8 4 4 8 9 1 5 2 1 2 3 2 3 1 2 1 1 6 0 11 1 8 1 7 4 9 9 3 7 5 2 2 3 1 2 2 1 5 2 1 2 1 2 5 1 2 5 3 3 7 1 8 0 10 1 4 5 4 1 3 2 5 2 8 1 1 3 3 3 3 1 2 1 5 0 11 7 2 6 6 3 1 4 4 7 5 4 1 1 1 1 2 1 8 0 10 3 5 9 5 1 7 1 6 3 5 3 1 3 2 2 1 3 2 3 5 1 2 2 3 5 3 4 1 5 0 8 7 1 2 4 4 5 3 1 1 1 1 2 3 1 7 0 7 1 1 8 3 1 6 5 1 2 1 3 2 2 3 1 5 0 7 7 1 1 9 1 2 4 1 1 1 1 3 1 3 5 2 3 7 1 6 0 9 6 4 6 8 1 4 1 5 9 1 1 1 3 1 1 1 5 0 11 5 1 6 3 6 3 7 2 8 5 4 1 1 1 3 1 1 9 0 10 7 2 1 1 3 2 4 4 8 3 2 1 3 2 1 1 2 1 1 3 1 3 2 2 5 5 3 6 1 6 0 10 6 7 9 4 8 5 5 6 2 1 2 1 3 1 2 3 1 7 0 9 4 6 1 7 4 5 8 1 1 1 3 3 1 2 1 3 1 6 0 9 3 1 7 8 6 7 4 6 4 2 1 2 3 2 1 4 5 4 1 2 1 3 4 1 6 0 7 1 6 1 6 1 8 5 1 2 1 1 1 2 1 7 0 7 3 5 1 1 1 5 3 1 2 1 1 2 3 2 1 5 0 10 2 3 2 8 7 9 9 7 9 1 3 1 1 2 2 3 3 2 4 5 4 7 5 4 3 7 1 9 0 7 7 4 1 6 7 5 7 1 3 1 2 1 1 3 3 3 1 8 0 11 6 8 9 7 1 3 9 9 6 4 7 1 3 3 2 1 2 2 3 1 6 0 10 4 1 5 7 8 7 4 3 4 9 3 3 1 1 1 2 2 4 1 1 4 1 5 3 7 1 5 0 6 2 7 9 9 8 1 3 2 2 1 1 1 7 0 6 9 7 1 6 7 1 3 1 2 1 1 2 1 1 6 0 7 1 3 9 3 8 2 3 1 1 1 1 1 1 4 1 3 3 4 3 3 3 7 1 8 0 9 8 7 2 2 9 1 5 2 8 1 2 2 2 1 3 3 2 1 8 0 8 7 3 7 3 4 4 1 4 1 2 3 3 2 1 3 1 1 5 0 6 4 9 3 1 5 7 3 3 2 2 1 2 3 4 1 1 3 2 3 4 1 7 0 6 6 5 5 1 2 5 3 1 1 2 3 3 1 1 5 0 11 4 3 8 1 3 3 1 5 9 1 8 1 3 1 3 1 1 7 0 10 6 2 2 1 3 4 1 9 5 1 2 2 1 1 2 2 1 3 4 4 5 3 7 1 8 0 7 9 1 2 3 8 7 1 1 3 3 1 3 2 3 3 1 6 0 10 9 2 7 2 4 6 7 1 9 6 2 2 1 2 1 1 1 9 0 8 4 9 3 4 4 1 9 8 2 3 3 2 1 2 3 1 3 3 3 3 5 5 2 3 5 1 1 6 4 3 3 7 1 6 0 9 4 1 1 8 1 1 4 9 2 2 2 2 3 1 1 1 7 0 8 7 9 1 1 3 4 9 6 2 3 1 2 1 3 1 1 8 0 10 3 1 4 7 9 1 8 1 6 1 2 2 2 1 3 2 1 2 2 2 3 2 2 1 5 3 5 1 8 0 10 8 7 1 9 4 5 5 3 8 6 3 1 1 3 2 1 3 1 1 5 0 9 9 9 1 9 5 2 9 1 5 3 1 1 3 2 1 9 0 11 5 9 7 7 8 6 1 7 5 3 1 1 3 1 3 1 1 3 2 2 1 1 1 5 5 3 4 1 8 0 7 8 9 4 2 1 5 7 2 1 1 2 1 2 1 2 1 9 0 6 7 1 6 1 2 1 1 2 1 2 3 3 1 3 2 1 7 0 11 4 7 2 4 9 1 9 8 6 7 5 3 3 3 1 1 2 2 5 1 2 5 3 6 1 7 0 9 9 5 1 6 4 9 9 7 8 2 3 3 1 3 1 2 1 8 0 6 8 5 6 1 1 4 2 3 1 2 1 1 3 2 1 8 0 7 4 1 2 5 7 7 4 1 3 1 2 2 3 3 3 5 3 1 5 1 2 6 5 3 1 3 1 7 3 5 4 3 5 1 9 0 8 2 7 2 6 4 9 1 9 1 1 2 1 1 3 3 2 3 1 7 0 9 1 5 3 5 9 9 7 3 5 3 1 3 1 2 1 3 1 6 0 6 1 4 7 1 1 8 3 2 3 1 3 1 5 1 1 1 3 3 6 1 5 0 8 7 3 7 9 1 3 2 2 3 2 1 1 1 1 8 0 11 7 1 3 7 4 1 5 1 4 4 3 2 3 1 2 3 1 1 3 1 8 0 11 3 4 6 8 1 1 4 1 8 2 7 3 1 1 3 3 2 3 1 4 2 3 5 4 4 3 5 1 6 0 7 7 5 7 9 1 1 8 2 1 2 2 2 3 1 7 0 6 8 9 1 9 6 2 2 3 1 1 2 2 3 1 9 0 10 1 9 5 2 8 8 3 2 5 3 1 2 2 2 2 1 1 2 2 1 1 1 5 3 3 6 1 7 0 11 9 5 1 5 1 1 4 3 2 4 9 1 1 3 2 1 3 2 1 7 0 7 5 8 9 7 8 9 1 2 3 3 1 1 1 1 1 6 0 10 9 1 3 7 9 1 1 4 7 6 3 1 3 2 3 1 3 2 2 3 5 4 3 5 1 9 0 8 8 3 3 4 3 1 4 6 1 2 3 1 3 1 2 3 2 1 8 0 6 1 8 1 4 4 1 2 3 1 1 2 1 3 2 1 8 0 7 1 6 4 9 5 4 9 1 3 3 2 2 3 3 3 3 4 4 1 4 1 6 7 6 5 5 3 6 1 8 0 10 2 4 9 5 1 5 9 3 7 1 3 3 3 3 1 1 1 1 1 6 0 9 1 1 1 3 2 7 2 1 5 2 1 3 2 1 2 1 6 0 11 2 9 9 1 1 6 5 2 4 9 7 3 2 1 1 1 2 2 4 1 2 1 2 3 7 1 5 0 11 1 6 3 2 6 4 9 5 2 2 1 2 3 3 1 3 1 8 0 10 4 7 4 7 1 9 9 6 1 1 1 1 2 1 1 1 3 2 1 9 0 6 1 7 4 2 6 3 2 1 2 1 3 3 3 2 1 2 2 2 2 3 4 4 3 4 1 8 0 6 1 4 4 6 5 9 3 1 2 3 2 1 1 2 1 8 0 8 8 1 9 2 1 6 1 7 3 3 3 2 2 1 3 1 1 9 0 9 1 9 8 6 4 4 1 9 4 1 3 3 1 1 1 1 1 2 4 3 1 3 3 6 1 7 0 10 8 1 1 4 4 9 3 3 2 6 1 2 2 3 3 1 2 1 6 0 11 4 6 6 1 3 4 9 1 4 9 6 2 1 1 1 2 3 1 7 0 7 1 3 8 1 9 6 7 1 2 1 1 2 3 1 1 3 3 3 1 5 3 4 1 9 0 9 6 2 7 4 1 9 3 4 2 2 3 2 3 3 1 1 1 3 1 6 0 9 1 1 3 4 2 4 9 7 6 3 3 2 1 1 1 1 5 0 10 1 9 5 4 8 1 4 9 2 9 2 1 1 1 3 1 3 4 2 1 5 1 7 6 5 5 3 7 1 5 0 11 8 4 1 9 3 8 2 2 3 9 8 3 1 3 3 1 1 9 0 8 5 6 2 1 7 3 1 2 2 1 1 1 1 1 3 1 3 1 7 0 6 2 1 8 8 7 3 2 1 2 1 1 1 3 1 3 3 2 1 2 2 3 4 1 9 0 8 8 5 6 1 9 7 1 1 2 1 2 1 2 1 1 1 2 1 8 0 9 3 7 8 8 2 8 3 1 9 3 3 2 2 3 1 2 3 1 8 0 8 9 5 4 4 9 1 3 5 1 1 1 3 2 1 1 3 5 5 2 2 3 5 1 7 0 10 4 3 7 1 2 1 1 3 5 8 2 2 1 2 1 3 2 1 8 0 11 1 1 2 7 6 6 1 9 5 8 8 2 3 1 3 3 1 2 2 1 8 0 9 6 9 8 9 1 8 6 8 8 1 1 3 2 3 2 1 3 3 2 1 2 1 3 5 1 5 0 9 6 2 5 4 8 7 4 1 8 1 1 3 2 1 1 6 0 7 5 9 3 3 9 1 2 1 1 1 3 2 1 1 9 0 10 1 1 9 6 7 2 6 9 9 8 1 1 3 2 1 3 2 2 1 4 2 5 4 5 3 7 1 7 0 6 5 7 7 2 1 8 1 2 1 3 1 1 2 1 5 0 9 9 7 4 2 4 1 3 1 7 2 3 2 1 2 1 9 0 6 1 1 9 1 1 1 3 1 1 3 2 3 1 1 2 1 1 2 2 5 2 5 2 1 6 4 5 5 3 3 7 1 7 0 9 4 1 1 8 6 4 7 4 1 2 1 1 2 2 2 3 1 7 0 7 7 4 6 3 1 4 9 3 3 1 3 3 1 3 1 6 0 8 2 6 1 1 3 4 2 3 1 2 1 1 2 2 5 1 4 1 5 3 3 3 6 1 9 0 10 7 1 4 5 7 9 2 4 2 1 1 3 1 1 1 1 3 2 2 1 5 0 6 2 1 4 5 6 4 1 2 1 1 1 1 6 0 10 5 2 2 6 1 6 6 1 6 9 3 3 2 1 1 1 2 4 2 2 2 2 3 5 1 8 0 8 1 1 9 2 7 5 4 8 1 2 1 3 2 3 3 3 1 9 0 10 8 3 3 7 5 6 4 1 9 2 1 3 1 1 3 2 1 2 2 1 5 0 6 1 9 1 4 1 9 1 2 1 2 2 1 3 3 1 2 3 4 1 7 0 7 6 4 1 6 7 5 1 3 3 3 1 1 3 1 1 7 0 11 9 8 9 6 1 5 3 1 2 4 2 1 2 1 2 3 1 3 1 9 0 8 9 6 9 1 7 6 8 4 1 1 2 3 3 3 1 3 1 2 3 2 4 3 6 1 5 0 8 5 4 3 3 2 1 6 1 2 1 3 3 3 1 9 0 6 6 5 6 3 1 7 1 2 1 3 1 2 3 2 3 1 7 0 8 3 4 1 1 5 9 2 2 2 1 2 1 1 1 2 1 2 3 1 2 1 4 1 3 5 5 3 7 1 5 0 7 8 7 7 3 5 1 5 1 1 1 2 1 1 9 0 9 6 6 6 1 2 9 1 9 3 3 2 1 3 1 3 1 2 1 1 9 0 11 9 3 4 1 8 9 8 8 9 9 5 1 1 1 2 3 1 3 3 1 3 1 1 5 3 4 2 3 6 1 8 0 11 7 9 1 6 1 1 4 4 8 6 1 3 2 3 2 2 1 1 1 1 8 0 11 5 6 2 1 2 4 5 6 7 6 1 3 1 1 3 3 1 1 2 1 7 0 11 3 3 5 1 4 7 8 1 8 7 1 1 1 1 1 1 2 1 2 1 2 3 2 1 3 7 1 8 0 9 8 9 4 6 1 1 8 4 3 1 3 2 2 1 3 3 2 1 7 0 7 7 8 9 7 1 2 6 2 1 1 2 2 1 1 1 9 0 6 3 1 4 8 2 1 1 1 3 2 2 1 2 2 2 2 4 3 2 3 1 5 3 7 1 8 0 6 4 1 4 5 6 9 3 1 2 3 2 1 2 1 1 5 0 11 1 8 3 6 6 4 1 6 4 2 1 3 2 3 1 3 1 8 0 9 8 6 1 2 8 9 5 5 9 2 1 1 1 1 3 2 3 3 2 3 3 5 3 1 3 6 1 6 0 7 9 1 8 4 2 1 9 2 1 2 3 1 2 1 5 0 8 1 5 1 9 3 2 6 6 3 1 3 2 1 1 6 0 6 9 9 7 2 7 1 2 2 1 1 3 1 1 2 5 1 2 2 3 1 7 2 2 5 4 3 4 1 5 0 11 2 7 6 6 5 7 1 8 1 8 2 3 1 1 2 2 1 5 0 10 6 9 3 7 4 4 1 2 4 6 3 2 2 3 1 1 8 0 11 5 4 3 7 7 4 4 5 9 9 1 3 2 1 1 1 3 3 3 5 3 2 1 3 4 1 7 0 9 2 3 6 7 1 1 2 5 9 3 1 1 3 2 1 1 1 9 0 6 9 7 4 7 2 1 1 2 1 3 1 1 1 2 1 1 7 0 11 1 2 9 1 7 5 6 6 6 2 5 1 2 1 1 3 1 3 4 1 3 2 3 4 1 8 0 8 6 3 1 6 5 7 1 8 2 2 3 3 1 2 1 3 1 7 0 7 3 1 5 8 1 5 2 2 1 2 3 2 1 3 1 6 0 11 1 7 2 6 1 1 6 4 9 8 2 1 3 1 3 2 1 5 3 1 5 3 7 1 7 0 11 8 4 7 3 1 9 1 8 7 8 2 3 1 3 3 1 3 1 1 7 0 9 2 3 1 4 4 9 8 1 9 1 3 3 1 1 2 1 1 8 0 9 6 2 7 1 8 8 2 5 7 2 2 3 2 2 1 3 2 4 4 1 2 2 2 1 3 4 1 6 0 6 7 9 9 1 2 1 2 3 2 1 1 1 1 6 0 6 5 7 5 2 2 1 2 2 3 1 1 1 1 9 0 8 3 5 5 6 2 5 6 1 1 2 3 2 2 3 3 1 2 3 1 4 1 3 5 5 2 5 3 3 6 1 7 0 7 4 4 4 2 1 4 5 3 3 2 1 1 3 1 1 6 0 7 5 9 1 2 1 7 3 3 1 2 3 3 3 1 6 0 6 1 7 1 1 9 9 1 3 1 3 2 2 1 3 5 4 3 2 3 7 1 6 0 11 1 1 7 5 2 9 2 3 3 6 8 3 3 1 2 2 3 1 8 0 10 3 5 9 4 6 5 1 5 6 4 3 2 3 2 1 2 1 1 1 5 0 7 6 4 9 4 7 9 1 3 3 1 1 1 4 2 1 3 5 3 4 3 4 1 9 0 11 6 1 3 8 1 5 7 9 5 3 1 2 1 1 1 2 2 1 1 1 1 5 0 10 2 8 8 5 9 4 8 6 6 1 2 1 1 2 1 1 5 0 8 1 1 1 7 7 5 2 5 2 3 1 3 2 3 1 3 2 3 6 1 8 0 10 3 2 1 5 4 7 9 3 8 7 1 1 1 2 3 2 1 1 1 8 0 11 8 5 4 1 5 6 2 5 8 3 1 2 2 3 1 1 3 3 3 1 7 0 7 4 8 7 3 1 1 3 1 3 2 3 1 3 3 2 3 4 4 5 5 3 5 1 5 0 6 4 7 1 3 1 9 2 2 2 1 1 1 6 0 6 1 9 1 8 7 2 2 2 1 1 2 2 1 8 0 7 1 2 4 2 7 4 3 1 1 1 1 3 2 1 3 1 2 5 4 3 5 5 1 3 5 2 5 4 1 3 4 6 8 8 8 3 1 \ No newline at end of file diff --git a/Sources/AOC2018/day08.swift b/Sources/AOC2018/day08.swift new file mode 100644 index 0000000..7a34bd2 --- /dev/null +++ b/Sources/AOC2018/day08.swift @@ -0,0 +1,169 @@ +// +// Advent of Code 2018 "Day 8: Memory Maneuver" +// + +import Foundation + +struct Header { + var nChildren = 0 + var nMeta = 0 +} + +struct Node { + var header = Header(nChildren: 0, nMeta: 0) + var children: [Node] = [] + var meta: [Int] = [] + var length = 2 // Smallest node is only a header with no children or meta data +} + +class Maneuver { + var treeData: [Int] = [] + var sumMeta = 0 + + // Supply filename for input ex: '/home/peterr/AOC2018/Sources/AOC2018/data/day08.txt' + init(withFile filename: String) { + let tree = Tools.readFile(fromPath: filename) + let chars = tree.components(separatedBy: " ") + for char in chars { + treeData.append(Int(char) ?? -1) + } + } + + // Supply test data in the form of a String + init(withString tree: String) { + let chars = tree.components(separatedBy: " ") + for char in chars { + treeData.append(Int(char) ?? -1) + } + } + + // get length of node and sum th meta data for Part 1 as a by-product + func getLength(ofChild childData: ArraySlice) -> Int { + let nChildren = childData[childData.startIndex] + let nMetaIndex = childData.index(after: childData.startIndex) + let nMeta = childData[nMetaIndex] + var length = 2 + + if nChildren == 0 { + let start = childData.startIndex + 2 + let metaData = Array(childData[start..) -> Node { + let nChildren = childData[childData.startIndex] + let nMetaIndex = childData.index(after: childData.startIndex) + let nMeta = childData[nMetaIndex] + var metaData: [Int] = [] + let children: [Node] = [] + var retVal = Node(header: Header(nChildren: nChildren, nMeta: nMeta), children: children, meta: metaData, length: 2) + + if nChildren == 0 { + let start = childData.startIndex + 2 + metaData = Array(childData[start.. Int { + var retVal = 0 + if (node.header.nChildren == 0) { + for meta in node.meta { + retVal += meta + } + } else { + for meta in node.meta { + let childIndex = meta - 1 + if (0.. ()) = day08Tests + lazy var final: (() -> ()) = day08Final + + let testData = "2 3 0 3 10 11 12 1 1 0 1 99 2 1 1 2" + // 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 + // A----------------16---------------- + // B-----5----- C-----6----- + // D-3--- + + func testManeuverInit() { + var maneu = Maneuver(withString: testData) + XCTAssertEqual(test: "testManeuverInit string", withExpression: (maneu.treeData[3] == 3)) + maneu = Maneuver(withFile: "/home/peterr/AOC2018/Sources/AOC2018/data/day08.txt") + XCTAssertEqual(test: "testManeuverInit file [3]", withExpression: (maneu.treeData[3] == 2)) + XCTAssertEqual(test: "testManeuverInit file last", withExpression: (maneu.treeData.last! == 1)) + } + + func testGetLength() { + let maneu = Maneuver(withString: testData) + let totalLen = maneu.getLength(ofChild: maneu.treeData[0...]) + XCTAssertEqual(test: "testGetLength", withExpression: (totalLen == 16)) + XCTAssertEqual(test: "testGetLength sum Meta", withExpression: (maneu.sumMeta == 138)) + } + + func testGetNode() { + let maneu = Maneuver(withString: testData) + let node = maneu.getNode(withChild: maneu.treeData[0...]) + XCTAssertEqual(test: "testGetNode", withExpression: (node.length == 16)) + } + + func testGetValue() { + let maneu = Maneuver(withString: testData) + let node = maneu.getNode(withChild: maneu.treeData[0...]) + let value = maneu.getValue(forNode: node) + XCTAssertEqual(test: "testGetValue", withExpression: (value == 66)) + } + + func day08Tests() { + testManeuverInit() + testGetLength() + testGetNode() + testGetValue() + } + + func day08Final() { + var maneu = Maneuver(withFile: "/home/peterr/AOC2018/Sources/AOC2018/data/day08.txt") + _ = maneu.getLength(ofChild: maneu.treeData[0...]) + print("Answer to part 1 is: \(maneu.sumMeta)") + maneu = Maneuver(withFile: "/home/peterr/AOC2018/Sources/AOC2018/data/day08.txt") + let node = maneu.getNode(withChild: maneu.treeData[0...]) + let value = maneu.getValue(forNode: node) + print("Answer to part 2 is: \(value)") + } +} diff --git a/Sources/AOC2018/main.swift b/Sources/AOC2018/main.swift index 53c3b53..ace17ec 100644 --- a/Sources/AOC2018/main.swift +++ b/Sources/AOC2018/main.swift @@ -19,6 +19,7 @@ allTests.append(Day04().tests) allTests.append(Day05().tests) allTests.append(Day06().tests) allTests.append(Day07().tests) +allTests.append(Day08().tests) // Compile list of Answers allFinal.append(Day01().final) @@ -28,6 +29,7 @@ allFinal.append(Day04().final) allFinal.append(Day05().final) allFinal.append(Day06().final) allFinal.append(Day07().final) +allFinal.append(Day08().final) if onlyOneDay > 0 { print("\nDay \(onlyOneDay)")