diff --git a/inputs/8.txt b/inputs/8.txt new file mode 100755 index 0000000..eaec743 --- /dev/null +++ b/inputs/8.txt @@ -0,0 +1 @@ +8 11 6 3 4 5 3 6 1 7 0 10 6 2 1 2 8 6 5 6 2 4 2 3 3 3 1 1 2 1 9 0 7 2 8 1 2 7 3 1 3 3 3 3 2 1 3 2 1 1 8 0 11 3 1 3 9 8 6 1 6 1 8 1 3 3 1 2 3 3 2 1 3 2 4 3 2 3 3 7 1 7 0 6 1 9 8 6 6 6 1 2 1 1 2 1 1 1 8 0 10 1 6 7 8 6 7 6 7 4 8 1 1 3 1 2 1 3 3 1 6 0 7 6 8 5 6 4 1 1 1 1 3 1 2 3 1 5 4 5 1 3 1 3 7 1 8 0 8 2 9 1 1 3 1 7 1 3 1 3 2 2 3 3 3 1 9 0 11 5 7 1 9 9 6 2 6 6 2 2 3 3 1 3 3 1 1 2 1 1 8 0 8 8 5 1 5 1 6 3 6 1 1 1 1 1 2 3 1 1 1 4 5 2 1 1 3 7 1 8 0 6 1 3 8 5 7 2 2 3 1 3 3 1 3 2 1 9 0 8 6 1 2 5 1 8 2 3 1 3 2 1 2 1 2 1 3 1 9 0 11 7 8 9 6 7 7 9 9 1 5 6 1 3 1 1 2 2 1 2 2 4 4 2 5 1 3 5 2 6 6 5 3 5 3 3 5 1 9 0 8 7 7 1 4 2 7 2 6 1 2 1 2 1 3 3 1 1 1 6 0 10 6 1 8 4 7 9 2 7 5 3 1 2 1 1 2 2 1 9 0 9 8 9 7 2 4 1 9 3 5 3 3 2 1 2 1 3 1 1 5 2 5 2 3 3 4 1 5 0 10 9 6 1 1 9 8 4 2 3 2 2 1 2 1 1 1 7 0 7 9 2 1 8 4 1 3 1 2 3 2 1 2 2 1 8 0 10 3 3 3 8 2 9 9 5 1 6 3 1 1 3 1 2 1 1 2 2 1 5 3 4 1 9 0 10 8 9 1 5 1 6 2 7 4 5 3 1 1 1 1 3 2 1 3 1 6 0 8 6 6 4 1 5 8 2 6 1 1 1 1 1 1 1 5 0 7 5 9 8 1 5 9 4 1 3 1 2 1 5 1 1 3 3 4 1 5 0 9 2 1 7 6 6 2 1 5 9 1 1 1 1 2 1 6 0 11 6 6 1 1 4 2 1 8 3 1 4 3 3 2 1 1 1 1 6 0 7 1 9 2 8 4 7 8 1 2 1 2 1 1 2 1 5 2 3 5 1 7 0 11 4 1 4 4 3 5 1 2 9 7 9 3 2 1 2 1 2 3 1 7 0 11 4 2 6 1 2 7 5 9 4 9 1 3 2 1 1 2 1 3 1 9 0 6 5 6 1 2 4 9 1 2 3 3 3 2 1 3 2 4 4 3 1 3 5 4 5 4 4 3 7 1 5 0 6 1 1 7 3 9 4 1 2 3 1 3 1 9 0 6 6 7 1 4 1 3 3 1 2 1 1 1 3 1 1 1 7 0 6 7 5 1 1 4 5 2 1 1 3 2 2 1 1 2 5 5 3 2 4 3 6 1 7 0 11 9 5 1 8 1 5 1 7 4 4 1 1 1 3 3 1 3 3 1 5 0 6 4 6 4 9 1 1 3 1 2 2 1 1 6 0 6 2 2 2 5 8 1 1 3 1 2 2 2 5 2 2 3 2 4 3 6 1 5 0 7 1 9 4 1 9 3 2 2 2 1 3 3 1 7 0 6 7 5 1 9 8 8 3 1 3 3 2 2 3 1 8 0 7 1 7 9 1 4 1 2 2 3 2 1 3 1 1 1 3 2 1 1 3 2 3 5 1 6 0 10 9 8 4 4 6 7 9 3 1 5 1 1 1 3 1 3 1 7 0 10 5 2 4 6 8 2 7 1 9 2 1 1 1 2 2 1 1 1 7 0 9 4 1 3 9 4 7 4 5 6 1 2 1 3 2 2 1 3 1 1 2 4 3 5 4 2 5 5 3 5 1 6 0 6 1 8 6 9 9 1 2 2 3 1 2 3 1 5 0 8 5 8 1 4 3 1 1 7 1 1 2 2 1 1 9 0 11 8 6 7 6 8 9 8 9 6 2 1 1 3 1 3 1 1 3 2 1 1 2 5 1 3 3 4 1 7 0 8 1 6 4 6 6 6 6 3 2 2 1 1 3 2 1 1 9 0 11 4 6 4 3 6 6 5 5 2 3 1 2 3 1 1 2 3 1 2 3 1 8 0 8 1 4 4 1 2 9 2 3 2 2 2 2 1 3 3 3 5 1 5 1 3 7 1 7 0 10 1 3 1 4 8 6 9 4 6 6 1 3 3 1 1 3 2 1 7 0 8 7 1 3 7 1 9 9 6 1 3 3 1 3 3 2 1 5 0 8 9 8 1 6 4 8 2 6 1 1 3 3 1 3 4 2 1 5 1 5 3 6 1 9 0 8 4 1 6 6 1 6 3 7 1 1 1 3 3 2 2 3 2 1 5 0 11 2 3 7 1 5 4 8 7 8 1 9 1 3 1 2 2 1 8 0 9 9 5 3 2 3 1 2 1 7 2 1 2 1 3 3 2 1 4 3 1 5 1 2 3 4 1 7 0 6 3 7 1 1 8 7 2 1 1 3 1 2 2 1 6 0 8 6 1 3 9 9 7 1 7 2 1 2 1 3 1 1 9 0 11 7 8 1 6 1 8 1 1 1 1 6 3 1 2 3 1 2 2 1 3 3 2 1 1 4 6 1 4 3 4 3 3 6 1 9 0 11 5 8 1 5 1 6 2 3 6 1 3 2 2 1 1 2 2 1 3 2 1 6 0 6 1 6 6 5 2 7 1 1 1 2 3 1 1 7 0 8 9 8 9 5 2 1 9 8 1 2 3 1 2 3 2 1 1 2 2 3 5 3 4 1 6 0 7 9 8 3 1 1 1 8 2 2 2 2 3 1 1 6 0 11 5 6 1 1 1 3 8 9 1 5 7 1 3 3 2 2 2 1 5 0 9 1 1 4 9 3 1 9 1 9 2 2 2 1 3 2 2 4 4 3 4 1 8 0 11 3 7 8 3 1 2 5 4 3 3 7 2 3 1 2 3 3 3 3 1 6 0 6 1 5 8 2 8 5 3 1 1 1 3 3 1 9 0 7 1 8 8 8 4 5 6 3 1 1 2 2 1 1 3 1 3 2 2 1 3 5 1 9 0 7 9 5 8 6 8 6 1 3 3 2 1 2 1 3 2 3 1 8 0 8 8 7 8 2 5 1 4 7 2 2 1 3 1 1 1 1 1 9 0 9 9 2 3 3 2 1 6 1 3 1 2 2 3 2 1 2 1 2 4 2 5 2 3 3 1 5 5 3 3 7 1 9 0 9 5 3 1 8 9 4 1 2 8 3 1 2 1 2 2 2 1 1 1 6 0 7 9 1 3 5 2 1 9 1 3 2 2 3 3 1 7 0 10 1 1 1 4 7 8 8 1 3 1 2 2 3 1 1 1 2 2 1 4 3 1 4 4 3 7 1 9 0 10 7 1 7 8 8 9 2 1 9 9 1 2 2 1 2 2 1 2 3 1 9 0 8 8 5 2 5 1 6 1 6 1 2 3 1 3 3 1 3 2 1 8 0 8 3 8 3 6 1 3 2 6 1 1 3 3 1 1 3 1 5 3 2 3 4 4 5 3 4 1 7 0 10 9 8 2 6 2 1 1 1 4 3 3 1 1 2 1 2 3 1 7 0 7 5 3 2 9 1 9 4 3 1 1 2 3 3 1 1 6 0 6 7 7 8 8 4 1 2 2 3 2 1 1 1 1 5 1 3 4 1 9 0 11 4 1 9 6 4 2 4 7 1 4 2 1 3 2 3 1 2 1 1 3 1 8 0 7 7 6 1 9 9 7 4 3 2 2 2 2 3 3 1 1 7 0 6 4 2 3 1 9 6 3 3 1 1 2 1 1 3 4 3 2 3 6 1 7 0 9 9 8 1 2 6 6 1 2 2 1 3 3 3 3 1 3 1 8 0 6 1 8 1 9 8 7 1 1 3 2 1 1 1 3 1 8 0 6 5 3 1 7 5 1 3 2 3 3 3 1 1 3 4 3 5 5 1 5 3 4 3 4 8 4 7 3 5 4 3 4 1 6 0 10 9 7 1 7 6 6 2 6 6 8 2 1 3 1 2 1 1 6 0 9 4 3 1 2 5 3 5 3 8 3 2 1 2 2 1 1 8 0 11 7 3 7 2 2 1 6 2 4 1 7 2 2 3 3 3 2 1 1 5 3 3 4 3 7 1 9 0 9 1 9 2 9 3 7 9 9 1 3 2 1 1 2 3 3 1 3 1 5 0 8 9 1 8 8 6 1 8 6 3 3 3 1 1 1 5 0 9 1 1 4 4 7 1 3 9 3 1 2 2 2 1 2 4 2 4 2 5 4 3 4 1 6 0 7 8 2 6 4 7 1 6 1 1 1 2 1 1 1 8 0 8 4 5 1 9 5 1 8 5 3 2 1 1 3 3 2 3 1 9 0 11 7 9 8 5 3 4 1 1 1 6 6 3 1 1 1 3 3 2 1 1 4 1 1 3 3 4 1 6 0 11 8 1 9 7 8 7 2 3 1 5 3 1 1 2 1 3 2 1 5 0 6 4 2 1 8 1 4 3 2 3 3 1 1 5 0 10 4 4 9 5 4 2 7 3 1 4 1 3 1 1 3 2 1 2 3 3 6 1 8 0 8 8 4 8 1 5 8 8 2 2 2 3 1 2 2 1 1 1 8 0 7 9 8 6 9 3 1 2 2 1 1 1 1 1 3 3 1 5 0 7 8 1 7 1 8 8 8 1 1 2 1 2 2 4 2 4 4 2 4 6 1 2 5 3 3 4 1 5 0 10 3 4 1 9 1 6 3 5 2 6 3 1 3 1 2 1 7 0 6 6 7 7 1 5 3 3 2 1 1 2 3 3 1 9 0 10 8 3 7 1 5 1 1 1 5 5 3 1 3 2 1 1 3 3 2 1 3 3 3 3 6 1 7 0 11 8 5 8 7 6 1 7 7 7 3 3 1 1 2 1 1 2 2 1 9 0 10 7 2 2 6 2 2 3 1 2 6 2 3 1 3 3 1 3 1 3 1 9 0 11 1 5 5 7 9 4 4 4 5 1 3 2 3 2 3 1 2 1 1 3 2 4 2 2 2 4 3 7 1 8 0 7 2 4 1 1 6 7 6 1 3 3 2 3 3 3 3 1 8 0 7 1 5 1 7 7 9 2 1 3 1 3 2 2 2 2 1 8 0 8 1 2 9 8 5 6 3 9 1 2 1 3 3 1 3 2 1 3 3 4 1 4 1 3 4 1 6 0 6 7 7 7 7 1 5 3 2 1 1 1 2 1 7 0 9 2 2 6 1 6 5 8 4 7 1 3 2 2 1 3 1 1 6 0 6 1 3 1 4 5 1 2 2 1 2 1 1 1 5 3 2 3 4 1 9 0 11 1 6 1 7 6 1 1 4 1 8 3 1 3 1 3 2 3 1 2 1 1 6 0 7 6 9 6 3 7 1 9 2 2 1 3 1 3 1 7 0 11 7 2 9 7 5 2 5 3 7 1 1 2 1 1 2 1 2 1 4 1 1 2 4 4 1 5 4 3 5 1 8 0 9 4 9 6 1 4 2 1 8 1 3 1 1 1 1 1 1 1 1 5 0 11 1 9 3 6 8 9 6 9 5 3 9 2 2 1 1 3 1 9 0 8 7 2 1 1 6 8 3 7 1 1 3 2 1 2 2 3 1 5 4 3 1 2 3 6 1 5 0 11 1 5 1 1 4 5 1 1 2 4 8 1 3 1 3 3 1 6 0 8 9 5 4 1 3 1 7 9 1 1 1 1 2 3 1 8 0 6 6 9 7 1 9 5 1 2 3 1 3 1 1 1 3 3 4 3 1 2 3 6 1 5 0 8 6 5 5 5 1 7 7 3 2 3 3 1 3 1 9 0 6 5 1 1 3 9 5 1 2 3 1 1 3 1 1 2 1 6 0 6 7 1 3 8 9 4 1 1 1 3 3 1 1 2 4 1 3 2 3 4 1 5 0 7 4 2 7 7 4 1 1 2 1 3 1 3 1 7 0 9 1 8 3 8 6 2 7 1 9 3 2 2 3 1 3 2 1 7 0 11 8 1 5 2 2 7 5 1 4 7 6 2 1 3 1 1 3 2 3 1 3 2 3 4 1 6 0 9 5 2 2 7 7 2 9 1 8 3 1 3 1 3 3 1 5 0 11 8 6 2 5 1 1 9 1 8 8 3 3 1 3 1 1 1 8 0 11 4 7 5 6 2 7 2 9 3 4 1 3 1 3 1 2 1 3 1 4 5 1 1 4 4 1 3 5 5 3 4 1 6 0 9 7 3 7 1 9 8 1 5 1 2 2 1 1 1 1 1 9 0 10 1 7 1 8 5 2 7 9 1 6 1 1 1 1 2 2 1 1 1 1 7 0 11 8 7 4 4 3 6 4 9 2 1 3 2 1 1 2 1 3 1 3 3 1 2 3 6 1 9 0 10 2 5 4 7 1 1 5 7 1 1 3 2 2 1 3 1 1 1 2 1 6 0 7 4 3 6 4 7 1 8 1 2 3 3 1 3 1 8 0 9 9 2 1 1 9 8 1 4 1 2 3 2 1 3 1 2 1 4 4 3 5 1 2 3 4 1 6 0 7 6 1 1 4 7 4 9 2 1 1 3 1 3 1 7 0 7 5 4 4 5 4 8 1 2 2 1 1 1 2 3 1 6 0 8 3 7 9 1 2 4 1 1 3 3 2 1 2 1 1 5 1 1 3 6 1 5 0 6 2 5 2 1 1 3 1 2 1 1 2 1 6 0 9 4 4 2 4 1 8 4 1 1 1 2 1 3 1 3 1 9 0 11 8 5 3 7 4 3 7 7 1 5 8 2 3 1 3 3 2 1 1 3 5 1 1 5 2 5 3 4 1 9 0 8 6 9 7 1 8 2 5 6 2 3 3 1 3 2 3 1 3 1 6 0 11 7 8 9 3 5 7 1 5 1 3 3 2 1 1 2 2 3 1 8 0 10 9 8 7 1 9 4 7 2 8 1 2 1 2 1 2 1 1 1 1 1 2 3 2 1 2 5 7 5 4 3 5 1 7 0 11 5 6 4 8 5 9 5 3 5 1 4 1 2 1 1 3 2 1 1 7 0 6 9 2 8 5 1 6 3 1 1 3 3 1 1 1 5 0 8 8 1 4 6 6 7 7 3 2 2 2 3 1 2 4 3 2 3 3 7 1 9 0 6 5 9 1 7 7 1 1 1 3 1 1 2 2 3 3 1 6 0 11 8 7 5 1 2 7 3 2 5 2 2 1 2 1 3 2 3 1 9 0 8 5 4 7 8 4 1 4 2 1 3 1 3 2 3 2 2 1 3 5 1 2 1 1 3 3 6 1 6 0 6 8 8 8 7 1 1 2 3 1 1 2 2 1 7 0 8 2 4 6 4 5 6 1 1 3 1 3 1 2 2 1 1 6 0 8 2 6 9 4 4 1 1 4 1 1 1 1 3 2 2 4 1 5 4 4 3 7 1 6 0 8 7 5 8 8 6 1 1 7 1 3 3 3 2 1 1 8 0 9 5 1 4 3 8 8 7 1 2 3 2 2 3 3 2 2 1 1 6 0 9 1 8 3 1 5 1 8 1 1 1 3 2 3 1 1 1 1 4 2 1 4 2 3 7 1 9 0 10 9 1 9 1 1 2 7 7 2 1 2 2 1 3 1 1 3 3 2 1 6 0 6 7 5 5 2 1 4 1 2 1 2 3 3 1 8 0 11 5 1 3 1 9 8 2 6 4 3 4 1 2 3 2 2 1 3 2 1 4 1 2 5 5 5 1 2 4 4 5 3 3 4 1 5 0 10 2 1 7 1 8 8 2 1 2 3 2 1 1 1 3 1 5 0 6 2 8 9 1 4 9 2 3 1 1 1 1 6 0 8 1 4 3 8 4 2 6 7 1 3 2 3 3 1 3 5 2 3 3 6 1 5 0 10 1 4 2 7 1 2 9 1 5 6 1 2 1 1 1 1 8 0 6 1 6 1 8 4 1 2 1 1 1 3 1 2 3 1 5 0 7 8 8 8 1 4 2 8 1 2 1 1 2 1 4 2 5 4 1 3 6 1 5 0 9 1 8 9 9 2 1 7 1 1 3 1 1 1 1 1 9 0 9 6 5 3 4 4 3 8 3 1 2 2 1 2 2 3 3 1 1 1 6 0 10 3 2 4 5 1 8 6 3 2 4 1 1 2 2 3 1 1 3 5 5 1 3 3 7 1 6 0 6 4 1 7 5 6 9 1 1 3 1 2 1 1 7 0 9 9 1 2 7 7 8 4 1 8 2 3 2 1 1 2 2 1 5 0 10 5 4 8 1 5 2 6 5 1 3 1 2 1 2 1 1 2 5 2 5 4 4 3 5 1 7 0 11 6 5 6 9 4 9 1 1 5 3 8 1 1 2 3 2 2 2 1 6 0 6 8 8 8 1 5 6 1 1 2 2 2 3 1 5 0 11 8 2 8 1 8 5 5 5 6 6 2 3 1 1 2 2 4 3 1 5 3 5 1 3 4 4 3 4 1 5 0 6 9 9 4 8 1 5 1 2 2 2 1 1 7 0 11 6 3 4 5 2 1 1 1 8 5 3 3 1 1 1 2 2 1 1 7 0 7 2 2 3 6 7 1 9 1 1 1 3 2 1 1 5 5 2 1 3 5 1 6 0 6 9 1 2 1 3 3 2 3 2 2 2 1 1 8 0 9 8 9 2 1 2 1 1 2 1 1 3 1 1 3 2 3 3 1 8 0 8 4 2 6 6 8 2 1 8 3 3 1 3 1 3 3 3 2 2 1 4 5 3 4 1 9 0 6 1 1 7 5 6 7 3 1 1 1 1 3 1 2 3 1 9 0 9 5 6 1 1 4 6 7 6 1 2 1 3 2 1 1 3 1 3 1 9 0 10 1 7 8 9 9 2 1 3 3 3 2 3 1 3 3 1 3 2 2 4 2 2 4 3 4 1 8 0 8 4 1 2 7 1 6 8 7 1 3 3 3 1 3 1 1 1 6 0 10 1 3 4 7 1 8 8 7 8 8 3 3 1 2 2 3 1 5 0 11 1 9 3 2 7 1 9 5 3 7 9 1 1 1 1 2 1 1 2 2 1 2 1 6 1 3 4 6 3 5 4 3 7 1 6 0 9 1 6 8 2 2 9 8 9 6 2 1 3 2 3 1 1 5 0 9 1 6 2 3 9 5 5 9 3 1 2 2 1 1 1 8 0 11 2 6 4 7 1 3 3 7 3 9 3 3 3 3 3 1 3 1 1 1 1 2 1 2 5 1 3 6 1 6 0 8 7 9 5 9 5 8 9 1 3 2 1 1 3 3 1 6 0 10 4 9 8 3 4 9 9 8 8 1 1 3 3 2 2 1 1 8 0 6 3 6 2 9 1 6 1 3 3 1 3 2 2 1 3 4 3 3 1 1 3 6 1 5 0 6 7 1 8 1 9 4 1 2 3 1 1 1 5 0 7 7 9 1 3 3 9 1 1 1 1 2 2 1 7 0 10 5 9 9 8 9 1 2 5 8 6 1 1 1 3 3 2 1 3 5 3 2 2 3 3 6 1 9 0 8 4 8 9 8 5 1 1 1 2 2 2 1 2 1 2 1 1 1 9 0 9 1 3 3 6 9 8 5 3 1 3 1 1 3 2 2 2 1 1 1 9 0 9 2 7 2 1 2 4 9 2 5 2 2 3 1 1 2 2 2 1 4 4 5 4 3 3 3 4 1 8 0 11 7 1 1 6 3 1 4 1 6 2 3 3 1 3 1 3 2 2 2 1 8 0 10 1 1 5 6 8 5 6 8 2 9 3 2 1 2 2 2 2 1 1 8 0 10 8 1 8 2 1 4 5 1 1 2 1 1 1 1 1 1 2 2 2 2 4 1 7 2 4 2 4 4 3 7 1 5 0 7 9 1 1 5 4 7 8 3 3 2 1 2 1 8 0 7 8 1 6 6 8 1 4 2 2 1 1 1 3 1 1 1 8 0 11 7 1 6 7 8 6 1 4 1 2 3 3 3 1 3 2 2 1 3 4 4 1 3 3 1 3 3 6 1 5 0 10 2 3 6 7 2 6 7 1 7 7 1 1 2 3 1 1 6 0 10 6 6 3 1 5 1 3 3 5 2 3 1 3 1 1 2 1 9 0 8 1 1 6 9 8 5 4 6 1 1 3 3 1 3 3 1 3 2 5 5 3 3 5 3 5 1 7 0 8 5 7 5 8 1 4 6 2 1 1 3 2 2 1 2 1 8 0 9 5 1 6 8 9 6 8 1 8 1 1 2 2 1 1 2 3 1 5 0 6 5 7 3 1 4 3 2 2 3 1 1 5 5 5 2 3 3 5 1 6 0 7 7 1 6 7 9 3 3 2 1 2 1 1 2 1 8 0 8 3 6 2 9 2 1 9 2 1 2 3 1 3 2 3 1 1 8 0 11 6 1 7 3 9 6 2 2 4 8 4 1 2 1 3 3 3 1 1 3 4 1 1 3 6 3 1 1 5 5 3 4 1 5 0 11 4 6 1 1 8 2 1 5 1 4 1 1 1 1 2 3 1 7 0 10 2 5 1 4 5 2 7 7 1 6 3 1 1 1 3 2 3 1 8 0 9 8 4 8 3 2 3 1 6 4 2 2 3 1 3 1 2 1 2 1 2 4 3 6 1 9 0 8 4 2 5 5 8 5 1 5 3 2 3 3 1 1 1 1 3 1 9 0 9 5 1 3 8 6 2 7 5 8 3 2 1 2 1 1 2 3 2 1 7 0 6 8 6 5 2 3 1 3 1 1 2 1 3 1 1 1 2 1 4 2 3 7 1 5 0 8 1 7 1 1 3 6 6 4 3 2 2 1 3 1 9 0 6 1 4 2 8 5 9 1 1 2 2 3 1 3 1 3 1 5 0 8 1 6 2 3 2 6 6 1 1 2 2 3 2 1 3 1 2 1 4 2 3 5 1 6 0 10 6 3 1 8 1 3 4 8 9 9 1 1 3 3 3 2 1 9 0 8 1 8 8 6 9 2 5 5 2 3 3 2 3 2 3 1 2 1 6 0 10 5 2 1 1 6 4 2 5 2 1 3 1 1 2 3 2 1 5 5 5 5 3 7 1 6 0 7 2 9 5 1 1 8 3 1 3 1 1 3 3 1 8 0 7 7 9 1 5 1 9 9 2 2 3 2 3 1 1 2 1 6 0 6 9 6 4 3 1 4 1 1 3 1 2 1 1 5 1 1 1 5 5 2 2 1 6 1 5 5 3 6 1 6 0 10 1 1 3 1 4 1 2 6 8 1 3 2 1 1 1 1 1 7 0 7 1 6 4 9 4 9 7 3 2 3 1 1 2 2 1 7 0 11 9 6 5 3 2 8 6 8 9 8 1 3 2 1 3 3 3 2 5 3 3 1 4 1 3 5 1 8 0 10 8 3 1 7 6 2 1 5 4 2 1 2 2 2 1 3 3 3 1 9 0 6 9 1 2 7 9 5 1 1 1 1 2 1 2 1 3 1 7 0 9 9 8 4 1 7 8 8 8 6 1 1 1 1 2 1 2 2 5 5 1 5 3 7 1 8 0 10 3 8 1 9 7 4 3 6 7 1 2 2 1 3 3 3 1 1 1 8 0 10 7 1 7 3 7 1 1 6 4 4 1 1 1 1 3 1 2 1 1 7 0 10 8 1 4 2 8 3 5 5 8 3 1 3 1 2 2 1 1 2 3 4 2 5 2 2 3 5 1 7 0 6 6 6 8 5 1 5 1 1 1 2 1 2 3 1 5 0 10 1 2 2 4 4 1 3 9 8 1 2 3 1 1 1 1 6 0 7 6 6 3 1 1 7 8 2 2 1 2 1 1 2 2 1 3 1 3 7 1 9 0 9 8 4 3 1 5 5 6 8 3 1 1 2 1 3 1 2 2 2 1 8 0 6 9 6 7 5 1 7 2 2 1 1 3 3 3 2 1 6 0 7 1 9 8 4 3 6 7 3 1 3 2 1 3 5 4 1 1 4 2 5 6 6 3 5 6 5 4 3 5 1 5 0 7 2 1 8 1 5 5 5 2 2 1 1 1 1 7 0 9 9 8 9 9 4 1 9 9 2 1 1 1 1 2 3 2 1 8 0 8 5 1 1 9 1 8 2 6 2 1 3 1 3 1 1 1 4 3 2 1 5 3 4 1 8 0 10 6 3 8 9 7 7 8 3 1 1 1 3 2 1 1 2 2 3 1 7 0 6 8 4 1 6 8 7 1 1 2 2 3 3 1 1 8 0 10 3 6 1 4 9 9 9 5 8 3 1 1 1 3 3 2 1 3 3 1 2 4 3 5 1 9 0 11 5 1 3 6 7 2 9 2 9 7 2 2 2 2 2 1 3 1 3 1 1 6 0 10 2 3 8 5 7 6 1 7 9 4 2 2 2 1 2 1 1 9 0 8 2 3 1 1 1 1 8 2 1 1 1 2 3 3 2 3 2 2 3 3 1 5 3 6 1 9 0 7 5 1 6 8 9 6 2 1 2 2 1 2 1 1 1 3 1 9 0 11 2 1 7 2 5 3 7 3 9 3 2 1 3 3 3 1 2 1 1 1 1 6 0 11 2 8 9 8 9 4 3 7 1 2 6 2 2 1 2 3 1 1 4 3 5 1 2 3 5 1 6 0 11 5 1 3 4 2 1 8 4 6 3 9 1 3 1 2 3 1 1 6 0 9 1 6 7 5 6 4 4 9 7 2 1 1 3 1 2 1 7 0 9 4 7 3 5 6 5 9 8 1 3 1 2 1 2 1 2 3 4 4 5 1 2 4 2 7 5 5 3 4 1 9 0 10 1 4 8 1 8 9 1 8 8 4 1 2 1 3 3 1 2 2 3 1 8 0 7 5 1 7 8 9 1 4 2 1 3 2 1 3 2 1 1 6 0 11 9 2 1 1 5 8 2 7 1 1 8 2 2 1 3 2 3 1 2 3 5 3 7 1 9 0 10 2 5 1 2 7 1 1 1 8 6 1 3 3 1 2 3 1 3 2 1 8 0 7 8 4 5 6 8 1 7 3 2 2 2 1 2 2 3 1 8 0 7 8 5 1 6 7 4 5 3 2 1 3 3 1 1 1 3 5 2 1 2 3 4 3 4 1 6 0 9 7 8 5 2 2 9 4 2 1 2 2 1 1 3 1 1 8 0 7 1 5 1 6 7 6 5 2 1 2 1 1 1 2 1 1 7 0 10 6 4 9 7 2 2 3 1 5 8 1 3 2 1 2 2 2 1 4 1 1 3 5 1 5 0 6 3 9 1 6 3 8 3 1 1 2 1 1 6 0 7 1 8 4 2 5 7 3 1 2 3 1 3 2 1 5 0 10 5 1 7 6 2 5 2 9 3 1 2 1 3 2 1 1 1 4 5 1 3 6 1 7 0 8 2 1 5 3 1 8 2 5 3 2 1 1 3 3 3 1 7 0 7 5 1 9 1 2 8 1 1 1 3 1 1 1 3 1 9 0 9 8 3 7 7 3 5 4 9 1 2 1 1 2 2 3 3 3 1 3 2 3 5 2 2 2 7 5 2 3 1 6 8 6 3 4 4 3 5 1 9 0 9 9 2 1 3 9 3 9 2 9 3 3 1 1 1 2 3 1 2 1 6 0 7 5 8 5 8 2 1 1 2 1 2 2 1 2 1 6 0 10 4 1 3 4 1 1 1 1 5 8 2 3 1 1 1 1 2 5 5 4 3 3 7 1 6 0 7 3 4 5 1 9 2 8 2 3 2 2 1 3 1 7 0 11 7 6 2 4 6 8 6 1 2 7 5 3 2 2 2 3 3 1 1 9 0 6 1 4 1 2 1 7 1 3 2 1 1 2 2 1 3 5 4 5 1 1 4 4 3 5 1 5 0 10 4 6 9 7 1 6 9 2 7 8 1 1 1 1 3 1 8 0 7 8 8 8 1 3 1 1 3 3 3 1 3 1 2 1 1 9 0 10 4 3 9 1 1 1 6 4 3 9 2 1 3 1 1 3 1 3 3 1 4 2 1 1 3 7 1 9 0 11 5 8 8 1 1 7 7 6 9 6 8 1 2 3 1 1 3 1 1 1 1 9 0 7 9 2 9 2 5 9 1 2 3 2 2 3 1 1 2 3 1 5 0 6 1 6 6 3 5 3 1 1 3 1 1 5 2 5 4 4 2 1 6 2 3 3 4 5 3 4 1 9 0 6 2 1 7 3 2 7 1 2 2 1 2 1 1 2 3 1 5 0 6 1 5 1 7 3 9 1 3 2 2 1 1 6 0 6 8 1 8 9 1 3 2 1 1 1 2 1 5 1 2 3 3 5 1 7 0 7 4 7 4 8 2 9 1 2 1 3 3 2 1 3 1 7 0 7 3 9 5 7 5 1 2 1 1 1 2 1 2 1 1 8 0 10 3 1 5 6 7 6 7 7 5 9 2 3 3 1 3 2 3 3 1 1 5 2 5 3 4 1 6 0 9 8 1 1 1 3 9 3 1 7 3 2 1 1 1 3 1 8 0 10 3 2 3 4 4 3 3 3 1 5 2 2 3 1 2 2 1 2 1 8 0 8 3 5 1 1 1 9 1 9 2 3 1 3 1 2 3 3 1 2 5 2 3 6 1 9 0 9 9 1 5 6 3 1 5 6 6 3 2 1 3 3 2 1 1 2 1 8 0 11 7 7 7 3 9 8 6 2 1 9 7 3 1 3 3 2 1 3 3 1 6 0 10 3 3 1 9 6 3 1 5 9 3 1 2 3 2 1 3 3 3 3 2 5 5 3 5 3 3 2 4 3 3 4 1 9 0 6 4 6 7 6 1 1 3 3 3 1 2 2 2 1 2 1 6 0 6 3 8 3 8 1 1 1 1 3 1 1 2 1 5 0 10 6 9 8 3 9 7 4 6 3 1 1 3 2 3 2 2 5 1 4 3 5 1 5 0 7 3 4 8 8 1 1 6 3 1 1 1 3 1 5 0 7 5 6 7 8 5 1 6 3 1 1 2 2 1 5 0 11 1 2 7 4 5 9 6 3 4 9 8 1 2 1 1 2 5 3 3 3 2 3 7 1 5 0 6 9 6 7 1 3 8 1 1 2 2 2 1 6 0 11 3 5 2 1 1 9 9 1 5 2 4 2 2 2 1 2 1 1 7 0 6 8 1 2 1 9 3 3 1 1 2 3 2 3 1 1 2 1 1 1 3 3 5 1 6 0 6 5 4 4 9 1 8 2 1 2 3 1 2 1 7 0 11 1 5 1 1 7 1 9 8 3 5 6 3 3 1 3 1 2 3 1 5 0 10 7 4 3 1 3 6 9 6 3 4 1 1 3 2 1 2 1 2 1 4 4 3 3 5 5 3 7 1 7 0 9 2 3 5 5 5 1 8 1 3 2 3 1 2 3 1 1 1 6 0 10 9 6 9 2 3 1 9 2 8 1 1 2 1 1 2 3 1 8 0 11 4 2 4 4 7 1 4 3 5 5 8 3 3 1 1 1 2 3 2 4 3 5 2 3 3 5 3 6 1 7 0 8 4 6 1 4 3 3 6 4 1 1 1 3 2 2 1 1 8 0 11 5 7 4 9 9 9 1 8 4 5 5 1 2 1 3 3 3 3 1 1 8 0 9 6 1 4 2 3 9 3 9 8 3 2 2 3 1 2 2 1 3 2 2 1 2 5 3 4 1 5 0 9 9 1 2 1 3 7 8 7 2 3 3 3 1 2 1 8 0 9 2 3 8 1 4 2 5 7 1 1 3 1 3 1 3 2 1 1 8 0 8 6 7 1 1 6 8 8 1 2 2 2 2 1 3 1 1 4 5 2 1 3 6 1 6 0 9 1 9 1 3 8 5 5 5 9 2 1 1 1 2 1 1 9 0 8 6 2 9 8 8 8 1 2 3 2 2 2 2 1 3 3 1 1 7 0 9 7 3 8 1 8 9 7 1 3 2 1 1 2 1 2 2 5 1 3 3 5 2 3 6 1 9 0 7 3 9 1 1 8 4 3 2 1 3 1 3 1 3 3 3 1 7 0 9 6 2 7 6 7 1 1 7 1 1 1 3 2 1 3 1 1 7 0 10 3 6 1 1 3 1 9 1 6 7 1 2 2 1 1 3 1 2 3 2 5 1 4 1 2 1 3 3 5 3 3 5 1 5 0 6 6 6 1 8 9 4 1 2 1 3 2 1 6 0 11 3 3 9 2 7 3 7 2 5 1 1 1 1 1 3 2 3 1 9 0 10 8 7 1 6 3 3 2 5 3 1 1 3 1 2 3 3 3 2 1 2 2 4 5 2 3 5 1 9 0 8 8 1 6 6 3 4 3 1 1 2 3 1 1 1 2 1 1 1 5 0 11 9 2 7 5 6 9 5 4 3 7 1 3 3 2 1 1 1 9 0 11 1 8 5 6 7 5 2 6 7 8 9 1 1 1 1 1 1 2 3 1 2 3 2 1 5 3 5 1 8 0 7 1 3 5 2 6 9 6 2 1 3 1 3 1 1 1 1 5 0 9 3 2 3 1 5 4 8 9 1 3 1 1 2 2 1 5 0 8 2 2 1 2 9 9 2 2 1 3 2 1 2 2 2 3 5 4 3 4 1 8 0 11 9 7 1 8 6 1 6 6 9 6 7 1 2 1 2 3 1 1 1 1 7 0 9 2 3 8 2 6 6 1 6 8 3 3 3 1 1 1 2 1 7 0 6 6 2 1 8 6 1 1 2 1 3 3 2 3 3 5 5 2 3 5 1 6 0 7 1 9 9 8 3 9 6 1 1 1 1 2 2 1 7 0 7 9 5 7 7 9 7 1 3 2 3 1 3 3 2 1 6 0 8 4 6 5 3 2 2 8 1 1 1 3 1 2 2 2 3 1 1 3 3 3 1 5 3 3 4 1 9 0 10 2 8 7 4 2 1 5 2 1 1 2 3 2 2 3 1 1 1 2 1 5 0 6 3 4 9 2 4 1 3 2 1 3 3 1 6 0 9 1 6 6 4 7 4 9 2 8 1 2 2 1 1 3 2 1 5 3 3 6 1 7 0 9 3 5 1 3 4 2 1 8 5 2 1 1 1 1 1 1 1 7 0 11 2 4 1 7 8 1 4 2 7 4 7 2 1 1 2 3 1 3 1 6 0 9 8 1 4 7 2 8 7 9 4 3 1 1 2 2 1 5 1 2 4 3 5 3 7 1 7 0 6 9 1 7 1 6 4 2 2 1 3 2 1 1 1 7 0 11 7 5 8 6 1 5 9 7 9 9 5 3 2 3 1 2 2 2 1 8 0 7 1 6 6 1 3 5 7 3 3 1 3 3 1 1 1 4 1 4 5 4 5 2 3 7 1 6 0 8 1 9 1 6 7 3 3 6 1 3 3 3 1 1 1 7 0 9 6 7 1 5 3 3 8 9 6 2 3 2 1 1 3 2 1 7 0 7 4 4 1 6 3 3 5 2 1 2 3 3 2 3 1 3 3 4 4 4 2 3 6 1 9 0 10 6 2 9 1 2 8 7 7 9 9 1 1 1 2 1 2 1 1 1 1 8 0 10 7 9 4 2 8 4 6 8 2 1 2 1 3 1 2 2 1 2 1 7 0 11 3 8 2 1 1 5 4 6 4 8 7 1 1 2 1 1 1 1 3 4 1 2 3 4 3 1 3 2 6 1 6 2 4 4 3 6 1 8 0 6 1 7 3 8 7 2 2 3 1 1 2 3 2 1 1 7 0 9 4 6 1 7 3 1 9 8 3 2 1 3 3 2 3 2 1 7 0 7 8 1 9 2 9 2 1 2 3 3 1 1 3 2 4 4 3 3 4 3 3 7 1 5 0 9 4 9 4 9 3 1 1 3 6 3 2 2 1 2 1 8 0 9 8 4 4 1 5 8 4 2 5 2 2 1 1 1 1 3 1 1 8 0 10 1 7 1 2 2 5 9 4 5 8 3 1 1 3 3 2 2 3 2 2 1 1 3 2 1 3 4 1 5 0 10 3 4 4 2 2 3 8 1 1 1 1 2 1 1 2 1 7 0 11 5 1 8 2 6 3 2 9 7 9 1 2 2 2 2 2 3 1 1 8 0 9 7 4 4 5 2 1 6 8 7 1 3 3 2 2 2 2 3 3 4 4 1 3 6 1 8 0 7 1 6 4 9 5 4 1 3 3 1 1 1 1 3 3 1 7 0 7 3 1 7 1 4 2 7 1 3 3 2 3 2 1 1 9 0 6 8 1 8 7 4 9 2 3 2 2 3 1 3 2 2 5 1 5 2 5 5 6 6 6 3 5 5 3 5 1 6 0 7 8 3 1 2 7 9 8 1 1 2 3 3 3 1 6 0 10 1 9 2 5 2 6 5 1 3 2 2 1 3 2 2 1 1 9 0 11 7 6 7 1 5 2 8 2 5 7 5 2 1 3 2 1 3 2 2 2 4 1 1 2 5 3 6 1 6 0 7 9 2 5 6 1 2 8 3 1 1 2 3 1 1 6 0 6 1 9 1 8 7 2 2 3 3 1 3 2 1 7 0 11 1 8 8 1 5 6 2 6 7 4 2 3 1 1 3 2 1 2 1 5 1 4 1 2 3 4 1 8 0 10 2 1 9 9 1 3 9 9 4 4 1 2 2 1 2 1 3 2 1 9 0 8 3 4 7 1 2 6 8 5 1 3 3 3 3 3 1 3 1 1 9 0 10 7 4 5 3 8 6 2 1 2 9 2 1 1 3 2 2 2 1 1 4 1 5 3 3 5 1 8 0 7 1 5 6 1 9 1 1 1 1 3 1 3 1 1 3 1 7 0 9 1 4 7 8 6 1 3 2 2 3 1 2 2 1 3 3 1 6 0 6 1 1 4 6 2 7 2 1 3 1 2 2 4 1 3 1 5 3 5 1 8 0 6 4 2 1 5 9 6 3 3 1 1 2 3 2 2 1 6 0 7 6 5 3 4 5 1 7 3 1 3 2 3 2 1 7 0 10 4 7 8 8 7 6 7 1 3 1 2 3 2 2 1 1 3 1 1 2 5 1 7 2 7 7 6 4 5 3 6 1 8 0 7 1 2 6 8 7 1 9 1 1 1 2 3 2 2 3 1 8 0 7 5 1 1 8 5 1 3 1 2 2 1 2 2 3 1 1 8 0 11 3 7 5 3 7 3 1 5 7 1 9 1 2 2 1 1 1 2 3 1 5 2 1 2 5 3 7 1 8 0 10 3 3 1 5 8 2 6 9 1 3 3 3 1 1 2 1 2 1 1 9 0 7 1 4 1 2 2 4 6 2 1 1 3 1 2 2 2 1 1 9 0 11 1 7 5 1 1 6 1 9 7 7 7 1 1 3 1 3 1 1 1 3 2 5 5 4 2 4 2 3 7 1 5 0 11 2 5 5 3 4 3 8 6 7 1 1 1 3 3 3 1 1 7 0 8 7 4 2 4 1 1 9 8 2 3 1 1 2 2 1 1 8 0 10 5 8 5 2 4 1 1 1 8 1 2 1 1 1 1 1 1 3 1 1 4 3 4 3 5 3 7 1 6 0 8 9 8 2 3 1 6 2 2 1 2 2 2 1 1 1 9 0 9 8 7 3 9 3 6 1 7 1 3 1 3 3 1 1 2 3 3 1 5 0 8 1 9 1 8 1 9 1 8 3 1 2 2 1 4 1 3 4 4 1 3 1 3 5 2 3 5 3 3 5 1 8 0 7 7 9 2 8 2 1 5 3 2 1 2 3 1 1 3 1 9 0 7 1 7 7 7 8 7 2 3 3 2 2 3 3 2 1 1 1 7 0 11 6 8 8 1 7 7 1 9 9 5 4 3 3 3 2 3 1 3 5 2 2 3 2 3 4 1 6 0 8 1 6 2 6 2 4 9 8 3 2 3 1 1 3 1 6 0 6 2 2 1 2 1 7 1 3 1 1 2 2 1 5 0 10 1 5 9 5 2 3 1 4 8 9 1 3 3 3 1 2 4 5 1 3 7 1 7 0 7 7 7 6 1 1 6 3 1 1 2 1 2 1 3 1 8 0 11 9 3 1 1 6 9 9 1 4 4 7 3 2 1 3 1 1 2 3 1 9 0 7 1 1 5 1 1 5 2 2 2 2 2 1 1 3 2 1 1 2 2 4 5 5 3 3 7 1 9 0 6 9 6 9 7 1 3 1 3 1 2 3 2 1 1 3 1 6 0 6 9 7 5 1 1 4 3 2 2 3 1 3 1 5 0 6 2 1 4 2 1 1 1 1 3 3 3 2 1 4 2 5 1 4 3 6 1 6 0 10 7 5 3 5 1 1 6 4 4 1 3 1 1 1 2 1 1 9 0 6 7 1 7 2 4 7 2 1 1 2 2 1 1 2 3 1 9 0 7 1 3 8 9 3 9 8 3 1 1 2 1 2 1 1 1 2 1 3 2 1 5 6 2 2 4 3 3 4 1 6 0 6 1 5 7 2 2 6 1 1 3 2 2 3 1 5 0 9 6 4 6 6 8 4 1 9 1 1 2 1 1 3 1 6 0 9 6 1 2 7 5 8 5 1 8 1 2 3 2 1 1 1 2 2 3 3 5 1 9 0 6 9 7 1 8 7 1 3 1 1 3 3 2 2 3 3 1 5 0 8 1 4 1 8 3 4 6 9 1 1 2 2 2 1 8 0 7 1 2 1 5 8 3 5 2 1 1 1 2 2 1 3 3 2 5 5 2 3 7 1 6 0 10 1 4 5 9 7 1 2 1 2 3 3 3 1 1 3 1 1 9 0 6 3 1 1 8 5 1 3 1 1 1 1 3 1 1 3 1 9 0 11 4 7 1 6 9 2 7 1 1 3 9 2 1 1 3 1 1 3 2 1 5 4 1 1 3 3 2 3 6 1 6 0 7 4 8 2 1 4 9 7 1 1 2 1 3 1 1 9 0 6 2 6 4 5 4 1 2 2 2 2 1 1 2 2 1 1 8 0 7 9 1 9 4 9 2 9 1 1 1 3 1 1 3 2 5 1 1 5 2 1 4 4 4 5 4 3 5 1 8 0 8 3 6 1 6 2 4 1 8 1 2 3 3 1 2 1 3 1 9 0 9 5 3 9 8 7 1 8 4 5 1 3 2 1 2 1 1 2 1 1 8 0 8 1 7 7 4 8 3 6 5 1 2 2 3 1 3 1 2 2 1 1 3 3 3 6 1 6 0 10 6 2 5 1 1 2 1 5 8 5 1 3 1 1 1 2 1 9 0 6 3 3 5 1 5 1 2 2 3 1 3 2 3 3 2 1 6 0 6 4 1 1 9 1 6 1 3 2 2 1 2 5 2 4 5 3 3 3 4 1 6 0 8 6 2 6 1 1 9 4 1 1 1 1 2 1 2 1 9 0 8 1 1 3 1 2 5 6 1 2 1 2 3 3 1 3 3 3 1 7 0 6 1 3 7 5 2 3 1 2 1 2 1 3 2 3 2 4 5 3 4 1 8 0 10 3 2 4 5 1 9 2 6 8 2 1 1 2 3 1 1 2 2 1 8 0 11 3 9 1 7 3 2 1 8 5 2 5 1 2 1 1 3 1 2 1 1 5 0 9 1 2 1 3 5 4 5 2 4 2 1 1 1 1 5 4 3 3 3 6 1 5 0 8 7 8 6 5 6 7 1 4 1 2 2 3 2 1 6 0 8 1 7 2 8 6 7 8 9 1 2 2 1 3 1 1 7 0 8 5 1 4 8 8 5 5 2 1 1 2 2 1 1 3 4 1 2 3 1 2 3 6 2 3 1 5 7 2 5 5 3 7 1 6 0 8 1 7 6 6 7 1 4 9 1 3 3 3 1 3 1 8 0 7 5 1 6 4 4 6 2 3 1 1 1 2 3 2 1 1 8 0 10 4 1 5 5 6 7 6 3 5 9 2 2 2 2 2 2 1 2 1 1 2 3 4 5 2 3 7 1 8 0 6 7 1 3 3 2 5 1 3 1 3 3 1 2 1 1 8 0 6 1 8 6 3 3 8 2 1 2 1 1 1 1 1 1 7 0 10 4 9 3 5 3 3 5 7 1 2 1 2 3 1 1 1 2 1 1 4 3 5 5 1 3 5 1 8 0 7 6 6 1 9 8 9 7 1 3 2 1 2 1 2 3 1 9 0 10 7 6 8 2 1 9 1 1 9 4 1 2 3 3 2 2 1 1 2 1 7 0 8 2 6 1 8 9 2 6 4 1 1 1 2 2 3 3 2 5 2 5 3 3 4 1 9 0 7 6 1 7 7 6 6 3 2 1 1 2 2 1 3 2 1 1 9 0 9 6 8 2 5 1 8 8 5 2 2 3 3 2 3 1 1 2 1 1 5 0 7 2 2 8 1 1 7 8 1 3 1 2 2 2 3 1 2 3 7 1 8 0 10 6 8 5 3 1 2 7 6 5 2 3 3 1 1 3 1 1 2 1 8 0 8 4 8 9 4 1 6 3 9 1 3 3 1 1 1 2 1 1 7 0 7 1 2 1 1 5 1 2 2 1 3 2 1 3 1 5 5 3 1 2 3 1 3 2 5 3 2 4 5 3 7 1 9 0 9 8 2 4 2 1 7 6 7 7 1 2 1 2 1 1 1 1 2 1 6 0 9 9 1 8 7 8 6 2 6 1 1 2 2 1 1 1 1 6 0 7 9 2 1 2 1 9 4 3 1 1 1 2 3 5 5 5 1 1 1 1 3 7 1 5 0 8 9 9 1 9 9 5 9 2 2 1 1 1 1 1 7 0 8 6 7 4 3 1 5 1 6 1 1 3 2 1 2 1 1 8 0 8 7 3 1 5 1 4 2 2 2 1 2 3 1 3 1 3 2 1 3 4 2 5 4 3 5 1 5 0 8 3 1 6 6 9 5 2 3 1 1 2 3 1 1 6 0 7 9 1 4 9 4 4 4 1 3 1 3 3 3 1 9 0 8 6 9 1 3 8 8 8 3 2 2 2 2 1 2 2 1 1 2 2 4 2 3 3 5 1 8 0 11 1 5 7 1 5 5 6 6 5 6 7 3 2 1 2 1 2 2 3 1 8 0 10 3 7 3 5 1 1 1 6 2 9 2 3 3 1 1 1 1 3 1 5 0 11 7 2 1 3 5 3 7 8 6 2 1 3 2 2 3 1 3 4 3 3 2 4 1 5 4 4 5 4 3 4 1 9 0 8 1 1 9 2 7 1 6 4 1 1 1 2 1 2 2 1 1 1 8 0 7 8 4 1 1 2 7 8 2 3 2 2 1 1 1 1 1 9 0 10 3 4 5 7 3 8 5 1 9 1 3 1 3 2 2 2 2 2 2 3 2 2 5 3 7 1 5 0 10 8 8 1 7 3 6 9 7 9 5 3 3 1 2 3 1 7 0 8 9 1 5 6 6 2 1 4 3 1 1 1 1 1 2 1 8 0 10 1 1 5 9 9 9 4 1 2 3 2 1 3 1 3 3 2 1 3 1 3 3 4 3 1 3 5 1 7 0 11 1 3 1 1 6 4 1 8 4 4 9 3 3 2 3 1 2 3 1 5 0 10 5 1 7 1 3 7 8 3 1 5 2 3 2 1 1 1 7 0 7 5 7 2 5 9 9 1 1 1 2 3 3 3 1 2 4 2 2 1 3 5 1 5 0 8 7 5 5 4 1 9 8 7 2 2 1 3 1 1 6 0 8 7 5 9 8 1 8 6 6 1 3 1 2 1 3 1 6 0 8 1 4 4 1 9 3 2 4 2 1 3 1 1 1 2 3 5 1 2 3 6 1 9 0 11 2 5 1 4 1 7 9 1 8 6 7 2 1 1 3 2 3 1 1 2 1 7 0 9 5 5 2 9 3 1 5 3 2 3 1 2 1 1 3 1 1 5 0 10 6 2 2 2 9 9 8 1 4 5 1 2 1 1 2 3 3 5 5 4 2 2 7 7 2 5 5 3 7 1 5 0 8 1 6 3 4 3 4 6 8 1 2 1 3 1 1 5 0 10 1 8 1 7 4 1 1 3 7 4 2 2 3 1 1 1 8 0 7 2 4 5 1 6 3 1 3 1 3 3 3 1 2 1 3 4 3 1 3 1 5 3 7 1 6 0 10 2 6 4 9 8 2 8 8 1 9 3 1 3 2 2 3 1 6 0 10 4 1 8 5 7 7 8 2 3 1 3 3 1 2 2 2 1 5 0 9 1 1 7 9 6 1 1 9 4 1 1 1 3 1 5 5 5 3 3 2 1 3 4 1 5 0 10 4 7 3 9 7 1 3 4 2 8 1 1 3 1 1 1 8 0 10 6 3 4 7 1 5 8 1 1 1 2 1 3 1 3 1 1 2 1 5 0 7 6 1 6 3 5 7 2 2 3 2 1 1 4 3 3 1 3 4 1 6 0 7 2 2 5 1 7 1 3 1 2 3 2 2 1 1 8 0 11 2 2 4 1 2 7 9 9 6 1 7 2 3 2 3 2 2 1 3 1 7 0 7 7 1 1 2 1 3 7 1 3 1 3 1 2 1 2 2 5 2 3 7 1 6 0 7 6 2 3 4 1 2 6 3 2 2 2 1 1 1 5 0 11 1 1 5 5 2 8 7 8 8 6 8 3 1 1 1 2 1 6 0 10 9 4 5 9 9 3 4 1 2 8 3 2 3 1 2 2 2 2 4 4 2 3 4 7 3 4 5 5 5 5 3 6 1 8 0 11 2 4 3 1 4 4 7 1 6 1 5 1 2 2 2 1 3 1 1 1 5 0 9 7 7 1 3 4 4 2 8 7 3 1 1 1 2 1 8 0 8 3 4 6 8 5 1 1 4 3 3 1 2 1 2 3 2 4 1 2 3 4 5 3 6 1 5 0 8 4 9 9 5 9 6 8 1 3 3 1 3 1 1 6 0 8 7 7 6 3 9 4 1 8 3 2 2 2 1 2 1 6 0 9 1 2 1 4 7 3 2 1 6 1 2 1 1 3 1 5 1 5 2 3 5 3 7 1 5 0 10 1 1 2 4 2 5 1 9 5 6 1 1 3 3 1 1 6 0 8 8 1 6 1 4 9 3 9 1 3 3 2 3 3 1 8 0 6 5 6 7 1 8 2 1 3 1 3 1 2 2 3 2 3 3 4 5 5 1 3 6 1 6 0 10 1 7 9 5 1 1 9 9 1 5 2 1 3 1 3 1 1 5 0 10 1 7 3 9 9 1 2 6 6 2 1 2 1 3 1 1 8 0 8 1 2 5 8 5 5 6 6 1 1 3 2 3 2 3 1 1 4 2 5 1 4 3 5 1 8 0 6 3 7 1 1 4 1 2 1 1 1 1 1 3 3 1 7 0 9 6 5 3 6 1 9 3 1 5 1 1 2 1 1 3 2 1 8 0 8 2 5 5 6 1 1 6 3 3 1 2 1 3 3 2 2 4 1 5 1 2 5 6 3 6 2 5 5 3 5 1 8 0 8 7 1 2 8 2 1 2 9 2 2 3 3 3 1 3 1 1 6 0 9 3 9 4 3 9 9 1 2 1 1 3 1 1 1 2 1 8 0 10 2 1 1 8 2 3 1 6 9 1 1 1 1 2 1 1 1 2 1 1 1 3 1 3 4 1 8 0 11 7 1 7 3 9 8 1 6 4 9 4 3 1 1 2 3 2 1 3 1 5 0 11 1 1 2 3 8 7 9 4 5 8 9 2 1 3 2 3 1 6 0 7 7 3 2 5 1 9 9 1 2 1 2 3 1 2 3 5 4 3 7 1 8 0 8 2 1 1 3 5 1 6 2 1 2 2 2 1 1 2 1 1 5 0 10 6 7 7 6 1 4 9 1 4 4 1 1 1 1 1 1 6 0 10 1 6 6 9 1 9 5 3 9 8 2 2 1 1 1 1 4 5 4 4 2 3 1 3 5 1 5 0 8 4 1 1 6 3 1 5 6 3 2 1 3 1 1 7 0 6 4 1 1 7 4 6 3 2 2 2 3 3 1 1 7 0 11 6 6 9 8 4 4 3 2 1 5 9 1 1 2 1 1 1 1 3 3 2 5 3 3 5 1 8 0 11 4 9 1 7 3 6 9 6 1 1 5 3 2 3 1 1 3 1 3 1 5 0 6 3 1 9 1 8 6 3 3 3 1 2 1 5 0 6 1 5 3 9 1 3 3 3 1 3 1 2 4 3 5 1 1 1 3 6 5 5 4 3 4 1 5 0 8 9 5 6 5 8 3 1 9 1 1 3 3 1 1 9 0 6 2 2 5 5 1 4 3 3 1 2 1 1 1 3 2 1 9 0 9 2 2 4 3 9 5 1 9 5 1 3 1 1 3 2 1 2 1 3 2 2 5 3 7 1 9 0 11 3 5 4 3 1 3 1 6 5 4 5 2 1 3 3 2 3 1 2 2 1 6 0 8 1 8 1 5 4 7 9 3 1 3 1 2 3 1 1 6 0 6 6 4 1 4 1 2 3 1 2 1 1 1 3 4 5 5 2 4 2 3 4 1 8 0 6 1 7 1 3 7 6 2 3 2 3 1 2 2 3 1 7 0 7 3 1 5 8 5 1 4 3 1 1 1 1 3 2 1 6 0 8 2 8 1 8 2 1 4 7 3 2 2 2 1 1 2 4 2 2 3 4 1 7 0 6 7 7 7 1 5 4 2 3 2 1 3 1 1 1 5 0 7 6 6 1 6 6 8 3 1 2 3 1 1 1 7 0 11 2 5 2 1 2 9 1 7 8 1 2 1 1 1 2 1 2 2 3 1 1 3 3 6 1 7 0 6 4 9 1 4 2 9 2 3 3 3 1 2 2 1 8 0 6 1 8 5 8 4 2 1 3 3 1 1 1 3 3 1 5 0 7 6 6 1 6 7 8 1 3 1 1 3 1 4 4 4 4 5 1 2 1 2 5 1 5 6 3 4 4 3 5 1 9 0 11 7 8 4 8 8 6 3 8 1 7 3 3 3 1 2 2 1 2 3 1 1 7 0 7 1 4 6 5 9 2 3 1 2 1 1 1 2 3 1 9 0 10 1 8 1 1 7 5 4 6 7 4 1 3 1 1 1 2 3 2 1 5 3 5 4 1 3 5 1 5 0 11 1 1 5 8 8 8 2 5 4 7 8 2 1 1 2 1 1 9 0 11 6 1 6 5 1 7 7 6 4 3 1 1 2 2 3 1 3 2 2 2 1 6 0 11 1 1 5 1 6 3 5 5 8 7 3 1 1 1 1 3 1 1 2 3 1 5 3 6 1 9 0 6 2 9 8 1 1 1 3 1 2 3 2 2 2 2 2 1 5 0 7 1 2 9 4 5 6 2 1 2 2 3 2 1 9 0 6 7 5 1 4 1 1 2 2 2 1 1 1 1 1 2 2 2 4 2 5 3 3 5 1 7 0 6 6 2 2 1 9 4 3 1 3 1 1 2 2 1 9 0 9 5 9 3 4 6 3 6 7 1 1 2 3 1 2 2 2 1 1 1 7 0 11 1 8 5 6 9 2 3 8 1 8 4 1 2 1 1 1 2 1 4 2 5 3 3 2 2 4 5 5 4 3 6 1 9 0 11 5 8 1 4 7 1 5 8 7 7 5 2 1 1 1 2 2 3 3 1 1 7 0 6 2 9 7 1 1 6 3 2 1 2 1 3 2 1 7 0 6 4 8 2 7 1 7 1 1 2 1 1 1 1 5 2 3 4 1 5 3 7 1 7 0 11 8 3 2 4 1 3 8 6 3 4 4 1 1 1 3 1 3 3 1 8 0 10 1 6 4 3 8 4 1 3 9 1 3 1 1 3 2 3 1 1 1 9 0 9 8 1 3 2 8 8 1 8 4 1 3 1 3 1 3 1 2 1 3 2 4 4 4 4 3 3 6 1 6 0 8 2 1 1 3 9 8 3 3 1 1 1 3 1 1 1 8 0 11 9 5 7 2 1 3 4 6 7 5 1 1 3 2 1 3 2 1 2 1 9 0 7 9 1 3 1 4 9 9 1 3 1 1 1 2 1 1 2 3 3 2 5 2 1 3 5 1 5 0 6 4 4 9 3 1 3 2 1 3 3 1 1 6 0 11 6 1 3 6 5 8 8 4 8 7 7 3 2 2 1 3 3 1 6 0 6 1 6 1 1 1 5 3 1 1 1 3 3 3 1 2 1 1 3 5 1 5 0 6 1 8 1 6 2 2 2 2 1 2 2 1 5 0 8 4 8 6 6 8 2 1 2 3 1 1 3 3 1 5 0 8 5 4 8 7 8 7 7 1 1 2 1 1 3 1 4 1 3 4 2 2 2 1 5 3 3 7 1 5 0 10 4 2 2 6 8 4 5 9 1 3 2 1 1 1 3 1 8 0 9 9 4 1 3 5 3 3 1 5 2 2 1 2 3 3 3 3 1 5 0 8 5 1 8 1 9 2 3 8 1 2 2 3 3 2 3 1 1 4 2 2 3 5 1 6 0 6 6 7 1 2 5 4 3 1 3 2 1 1 1 8 0 6 1 6 3 1 7 7 3 3 3 1 3 1 3 3 1 9 0 7 7 9 3 1 2 1 8 3 1 1 2 2 2 3 3 2 5 3 3 3 5 3 7 1 8 0 10 1 2 1 2 9 6 9 2 4 9 1 1 3 3 3 3 1 1 1 7 0 9 7 9 7 1 5 1 2 5 7 3 1 3 1 1 1 1 1 5 0 7 4 3 5 7 3 7 1 1 3 1 3 1 1 4 4 3 3 3 1 3 4 1 7 0 8 9 3 1 3 4 3 2 8 2 2 2 2 2 1 3 1 7 0 7 9 2 7 9 9 3 1 1 3 2 1 1 2 2 1 6 0 10 3 5 2 1 6 9 4 2 7 8 2 3 2 1 1 1 2 3 3 1 3 6 1 8 0 10 2 8 1 1 1 1 7 1 7 1 1 2 1 3 1 1 1 3 1 5 0 7 1 6 8 7 5 4 4 3 1 1 3 2 1 8 0 7 3 1 1 2 1 4 5 2 2 1 3 1 3 3 2 2 1 5 2 5 2 4 3 1 5 4 3 4 1 6 0 6 3 3 1 3 1 8 2 1 1 2 2 1 1 8 0 11 5 5 2 7 1 3 7 4 6 7 2 2 3 1 3 3 1 1 2 1 9 0 6 1 6 5 6 1 8 1 2 1 2 1 3 1 1 2 2 3 1 3 3 4 1 8 0 10 5 7 4 7 1 7 4 2 8 5 3 2 3 2 2 1 2 1 1 8 0 9 1 4 9 7 5 9 2 1 2 2 1 2 2 2 3 2 1 1 6 0 7 3 1 9 8 1 2 8 1 3 3 3 3 1 3 2 2 1 3 4 1 8 0 9 8 8 2 5 8 4 1 2 1 2 1 1 3 1 1 1 2 1 8 0 7 2 3 2 5 7 9 1 1 3 1 3 2 3 3 1 1 9 0 9 7 1 6 1 9 5 6 2 6 3 2 1 3 1 1 3 2 2 2 2 1 2 3 6 1 7 0 11 6 6 9 3 8 8 1 4 4 1 5 1 1 3 1 1 3 3 1 5 0 11 6 9 6 1 6 4 8 8 4 1 2 2 3 3 3 1 1 5 0 8 8 1 2 7 2 2 5 7 2 3 1 1 1 2 1 1 1 2 2 3 7 1 6 0 6 9 5 2 4 6 1 3 3 1 3 3 2 1 7 0 6 1 3 9 5 1 9 1 1 3 3 3 2 2 1 6 0 11 4 5 5 5 4 3 3 8 7 1 3 3 1 1 3 2 2 3 2 5 1 1 4 1 2 4 7 4 5 3 3 7 1 5 0 9 6 5 8 1 1 8 4 1 9 3 1 1 1 3 1 5 0 8 1 9 7 8 7 1 3 7 2 2 1 1 1 1 8 0 11 4 1 9 2 6 7 1 6 6 6 1 3 2 3 2 1 2 1 2 3 5 1 4 4 3 5 3 4 1 6 0 8 5 5 7 1 9 9 9 6 1 1 2 2 1 2 1 7 0 8 5 3 7 1 2 4 2 5 3 1 1 2 1 1 3 1 7 0 8 3 3 1 4 6 2 4 8 1 1 3 2 3 1 1 2 4 3 4 3 4 1 7 0 7 1 6 8 7 4 5 1 2 3 1 1 2 1 3 1 7 0 8 6 6 8 3 1 1 3 3 1 2 2 3 3 2 3 1 8 0 6 2 1 2 4 2 3 1 1 3 2 3 2 3 1 5 2 1 5 3 7 1 6 0 7 7 8 1 4 9 1 6 2 1 3 1 1 1 1 9 0 6 8 8 2 7 6 1 3 2 2 2 3 2 3 1 3 1 8 0 8 5 3 7 4 5 1 1 7 2 1 1 2 1 3 2 3 4 5 5 4 3 5 3 3 7 1 9 0 7 8 7 5 2 1 4 9 1 2 2 3 1 3 1 1 3 1 9 0 7 8 8 9 5 2 1 8 1 3 2 1 3 3 1 3 1 1 8 0 9 8 7 5 1 9 1 3 8 4 2 1 2 3 1 1 1 2 2 2 4 4 3 1 5 2 7 7 5 5 3 7 1 7 0 7 3 9 1 5 2 1 7 3 1 2 1 1 2 2 1 5 0 6 1 1 1 1 9 2 1 2 3 2 1 1 9 0 8 1 3 1 7 1 5 8 8 2 1 1 1 2 2 3 1 3 2 3 2 2 4 2 3 3 5 1 6 0 11 8 6 9 4 8 9 2 7 2 1 4 1 3 2 2 2 2 1 6 0 8 8 8 6 6 3 1 5 2 2 1 2 2 3 2 1 9 0 10 1 4 3 3 2 1 8 9 6 5 1 3 3 1 2 2 1 1 2 3 1 3 4 3 3 7 1 9 0 7 5 9 2 1 5 2 4 3 2 2 2 2 1 2 3 1 1 9 0 8 1 1 2 5 8 3 2 9 3 2 2 2 1 2 2 3 2 1 5 0 7 6 1 1 8 2 2 2 1 1 2 1 1 4 4 4 5 3 1 3 3 5 1 5 0 8 1 5 4 2 1 9 2 2 1 3 3 1 1 1 9 0 10 5 7 1 5 7 4 9 6 4 1 1 2 3 2 1 2 2 2 3 1 5 0 11 7 6 6 1 6 5 4 6 5 3 1 1 1 1 1 2 1 3 3 5 2 3 6 1 9 0 8 1 5 3 5 2 2 1 9 3 1 1 1 3 1 1 1 3 1 5 0 8 6 4 4 4 7 1 6 1 1 1 2 3 3 1 5 0 11 4 9 3 8 6 8 2 1 1 8 5 3 2 2 1 1 4 1 4 2 5 3 2 4 6 5 1 2 2 3 6 2 5 5 3 6 1 8 0 8 8 1 5 3 4 6 1 4 1 3 1 1 2 1 3 1 1 7 0 11 1 4 8 5 9 3 7 8 5 6 6 1 1 1 2 3 1 3 1 6 0 7 3 7 9 7 6 1 8 2 3 2 1 3 1 3 4 1 3 2 3 3 6 1 6 0 10 9 2 3 2 7 7 1 3 6 5 1 2 1 2 2 1 1 9 0 6 7 8 5 9 1 7 2 1 1 2 3 3 2 1 2 1 7 0 9 6 3 5 1 4 6 3 2 3 3 1 3 3 1 1 2 2 2 3 1 5 5 3 4 1 8 0 6 2 9 1 4 6 1 2 2 1 1 2 3 3 3 1 9 0 6 9 7 6 7 1 7 1 3 2 2 3 3 1 1 3 1 5 0 11 6 6 7 1 3 8 5 7 6 6 7 1 2 2 1 1 2 1 1 5 3 4 1 8 0 7 7 4 7 9 4 6 1 2 1 3 3 1 2 2 1 1 8 0 8 3 1 6 3 6 7 4 1 1 1 3 3 3 2 2 1 1 6 0 11 1 2 3 8 1 4 3 8 5 9 9 2 1 1 1 1 3 1 1 5 1 3 5 1 7 0 7 9 1 6 5 7 1 8 3 2 3 1 1 2 1 1 9 0 10 9 1 4 2 2 1 3 2 3 8 3 3 2 1 1 1 2 1 3 1 7 0 11 7 3 7 2 2 6 1 2 8 1 6 3 1 1 1 2 3 1 4 4 2 3 1 7 4 5 4 6 5 4 3 5 1 6 0 9 2 4 9 1 1 1 4 6 2 2 1 1 1 2 2 1 6 0 11 1 5 6 5 6 8 3 4 2 1 6 1 1 1 1 1 2 1 6 0 10 1 5 2 9 9 2 7 7 1 2 2 3 1 2 1 1 2 1 4 5 2 3 4 1 5 0 10 2 5 2 6 5 7 6 1 3 7 1 1 1 2 2 1 8 0 10 2 1 5 9 5 7 8 2 7 4 2 1 2 1 2 1 1 1 1 7 0 11 6 8 9 1 1 3 5 1 8 6 8 2 2 1 1 3 1 1 3 4 4 2 3 5 1 7 0 6 8 6 2 2 2 1 3 2 2 2 2 3 1 1 6 0 8 1 6 7 1 8 3 8 4 2 3 1 1 3 3 1 5 0 7 1 6 1 6 2 3 9 1 2 1 3 2 3 1 1 5 4 3 5 1 5 0 11 8 3 5 7 8 2 9 3 1 2 1 3 2 2 1 2 1 5 0 8 6 5 6 5 7 1 1 5 1 2 2 2 3 1 8 0 10 8 7 4 6 9 1 6 7 3 7 1 2 1 1 1 2 2 1 1 2 2 3 3 3 5 1 5 0 8 1 4 9 6 3 3 1 4 1 1 3 2 1 1 5 0 6 4 2 6 1 1 4 1 3 3 2 1 1 9 0 8 3 2 1 4 2 2 2 2 1 1 1 1 3 1 1 1 1 2 5 1 3 3 2 6 1 2 4 5 3 4 1 7 0 10 8 7 6 9 1 7 8 8 3 5 1 1 1 1 1 3 3 1 8 0 9 9 5 2 3 1 7 1 1 1 2 2 2 1 1 2 3 3 1 6 0 10 1 4 1 6 6 9 5 2 9 6 3 3 2 2 1 1 2 5 3 1 3 5 1 7 0 6 5 1 9 8 7 8 3 2 1 1 1 3 1 1 8 0 11 9 5 9 4 4 6 7 4 1 6 8 3 1 3 3 1 1 1 1 1 7 0 7 7 1 6 8 7 6 6 3 1 1 3 2 1 2 1 5 5 5 1 3 6 1 7 0 8 7 2 1 9 1 9 2 8 2 2 3 2 2 1 1 1 5 0 7 7 3 4 6 5 9 1 1 2 2 1 3 1 6 0 9 7 1 5 4 4 4 4 8 4 1 2 3 1 3 3 4 1 2 2 1 5 3 5 1 9 0 6 4 2 2 1 3 1 1 1 2 1 1 2 2 2 1 1 6 0 10 2 8 6 8 7 7 9 1 7 5 1 1 1 1 1 2 1 8 0 6 1 5 6 5 3 3 1 1 2 1 1 2 1 2 5 5 3 1 1 4 3 6 5 1 5 3 3 6 1 5 0 8 6 1 2 1 6 6 3 9 3 1 2 1 2 1 7 0 7 1 7 5 1 3 6 3 2 1 2 2 3 3 1 1 7 0 9 7 3 5 2 1 9 7 1 1 2 3 1 3 2 3 3 2 1 1 1 3 4 3 4 1 6 0 10 5 6 6 7 1 6 4 1 6 8 1 3 1 3 1 2 1 7 0 6 6 1 9 5 1 9 1 1 1 1 1 3 1 1 5 0 10 6 6 9 6 2 5 6 3 2 1 3 3 2 1 2 3 2 1 3 3 5 1 9 0 9 1 5 8 4 6 7 9 1 1 1 1 2 2 1 1 3 1 3 1 8 0 8 6 1 2 1 1 1 5 5 2 2 1 1 1 3 2 3 1 6 0 8 5 1 2 2 2 7 2 2 2 1 2 2 1 1 2 4 5 2 3 3 4 1 9 0 7 1 2 8 4 6 6 9 1 1 3 1 2 2 2 1 1 1 5 0 11 2 1 8 5 8 1 2 7 9 3 8 1 2 2 1 3 1 7 0 8 1 1 9 3 6 1 8 9 2 2 1 3 3 3 1 2 5 2 3 3 7 1 7 0 9 8 8 8 2 3 1 6 2 8 3 3 2 1 2 3 2 1 6 0 10 8 8 5 9 1 1 6 5 1 5 1 1 1 1 2 1 1 7 0 10 9 9 8 4 5 4 1 8 5 3 1 2 1 1 3 2 1 1 1 1 4 5 1 2 2 1 1 4 5 3 7 1 5 0 8 8 5 8 1 7 4 9 4 3 1 2 3 2 1 8 0 7 1 8 7 4 7 2 2 1 1 1 2 2 2 2 3 1 7 0 7 1 8 3 9 8 8 8 2 2 1 1 1 1 1 4 3 3 1 5 5 4 3 4 1 9 0 6 7 1 4 2 2 9 3 1 1 2 2 2 3 3 2 1 8 0 11 8 7 6 8 1 3 1 6 7 7 3 2 1 1 2 3 1 3 1 1 6 0 10 4 5 8 3 5 9 6 7 1 5 3 1 1 3 3 3 2 3 3 1 3 7 1 5 0 6 4 4 1 5 7 8 1 2 1 2 3 1 5 0 8 2 2 6 7 1 6 1 1 1 3 2 1 2 1 6 0 7 4 3 1 9 7 7 3 2 3 1 1 1 3 4 1 2 1 5 2 3 3 7 1 6 0 8 1 3 6 5 3 4 8 7 3 2 1 3 1 2 1 8 0 11 8 5 8 7 9 7 9 1 7 7 3 2 2 2 1 1 2 1 1 1 6 0 11 2 9 7 5 3 7 6 1 6 3 9 2 1 2 2 2 1 4 3 5 5 5 3 5 2 5 4 1 1 5 4 3 4 1 9 0 11 7 6 9 1 5 6 5 7 4 3 7 1 1 2 2 3 3 1 2 3 1 7 0 8 9 2 1 3 1 9 1 8 1 3 1 2 3 2 3 1 5 0 11 7 4 5 3 7 3 9 8 1 7 8 1 1 1 1 2 2 2 1 1 3 5 1 8 0 8 5 4 5 9 9 1 1 3 1 2 2 2 1 2 1 3 1 7 0 7 8 1 8 1 6 1 1 1 2 2 3 3 3 2 1 7 0 6 1 5 5 2 8 6 1 2 2 1 2 1 1 1 5 5 4 2 3 7 1 9 0 6 3 1 3 9 8 7 2 3 3 3 2 2 1 3 2 1 5 0 11 3 4 1 8 7 5 4 4 4 1 6 1 1 1 1 1 1 8 0 7 7 4 6 6 4 1 1 1 1 3 1 2 2 1 3 3 1 3 3 3 3 4 3 6 1 8 0 10 7 2 1 1 3 6 9 1 5 3 3 1 3 1 1 2 1 3 1 8 0 6 5 1 9 2 3 3 2 2 1 1 2 3 1 1 1 8 0 10 1 1 1 7 4 4 8 8 4 2 1 1 2 2 1 1 3 2 2 2 5 1 2 1 3 6 1 7 0 11 4 5 4 5 4 1 2 3 6 4 1 3 1 1 1 3 2 2 1 8 0 11 7 5 4 5 6 1 3 1 5 6 5 1 3 2 3 3 1 2 1 1 5 0 10 6 4 5 1 1 3 8 6 5 3 2 1 2 1 3 2 4 4 4 3 1 4 4 5 5 1 2 1 10 1 5 7 1 3 7 5 1 2 diff --git a/inputs/8_test.txt b/inputs/8_test.txt new file mode 100644 index 0000000..4279f52 --- /dev/null +++ b/inputs/8_test.txt @@ -0,0 +1 @@ +2 3 0 3 10 11 12 1 1 0 1 99 2 1 1 2 diff --git a/src/day8.rs b/src/day8.rs new file mode 100644 index 0000000..86c2072 --- /dev/null +++ b/src/day8.rs @@ -0,0 +1,60 @@ +use std::error::Error; +use std::fs; +use std::result; + +type Result = result::Result>; + +const INPUT: &str = "inputs/8.txt"; + +pub fn solve_part1() -> Result { + let license = read_license(INPUT)?; + Ok(sum_metadata(&license, 0, 0).0) +} + +fn read_license(filename: &str) -> Result> { + let license = fs::read_to_string(filename)?; + let license = license.trim(); + Ok(license + .split(' ') + .map(|num| num.parse().unwrap()) + .collect()) +} + +fn sum_metadata(license: &[u32], mut index: usize, mut sum_acc: u32) -> (u32, usize) { + let num_children = license[index]; + let num_metadata = license[index + 1]; + index += 2; + if num_children != 0 { + for _ in 0..num_children { + let (child_sum_acc, child_index) = sum_metadata(license, index, sum_acc); + sum_acc = child_sum_acc; + index = child_index; + } + } + if num_metadata != 0 { + let sum: u32 = license[index..index + num_metadata as usize].iter().sum(); + index += num_metadata as usize; + sum_acc += sum; + } + (sum_acc, index) +} + +#[cfg(test)] +mod tests { + use super::*; + + const TEST_INPUT: &str = "inputs/8_test.txt"; + fn test_license() -> Vec { + vec![2, 3, 0, 3, 10, 11, 12, 1, 1, 0, 1, 99, 2, 1, 1, 2] + } + + #[test] + fn reads_license_file() { + assert_eq!(read_license(TEST_INPUT).unwrap(), test_license()); + } + + #[test] + fn sums_license_metadata() { + assert_eq!(sum_metadata(&test_license(), 0, 0).0, 138); + } +} diff --git a/src/main.rs b/src/main.rs index ebc3368..75affd8 100644 --- a/src/main.rs +++ b/src/main.rs @@ -10,6 +10,7 @@ mod day4; mod day5; mod day6; mod day7; +mod day8; fn main() { // println!("Day 1:"); @@ -30,7 +31,9 @@ fn main() { // println!("Day 6:"); // println!("{}", day6::solve_part1().unwrap()); // println!("{}", day6::solve_part2().unwrap()); - println!("Day 7:"); + // println!("Day 7:"); // println!("{}", day7::solve_part1().unwrap()); - println!("{}", day7::solve_part2().unwrap()); + // println!("{}", day7::solve_part2().unwrap()); + println!("Day 8:"); + println!("{}", day8::solve_part1().unwrap()); }