diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1377554 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +*.swp diff --git a/04/.solve02.py.swp b/04/.solve02.py.swp deleted file mode 100644 index 103e477..0000000 Binary files a/04/.solve02.py.swp and /dev/null differ diff --git a/05/.solve02.py.swp b/05/.solve02.py.swp deleted file mode 100644 index 271b918..0000000 Binary files a/05/.solve02.py.swp and /dev/null differ diff --git a/06/.solve02.py.swp b/06/.solve02.py.swp deleted file mode 100644 index 926c4fd..0000000 Binary files a/06/.solve02.py.swp and /dev/null differ diff --git a/08/input.txt b/08/input.txt new file mode 100644 index 0000000..6d5dac7 --- /dev/null +++ b/08/input.txt @@ -0,0 +1 @@ +9 11 7 2 4 4 3 5 1 8 0 10 2 2 7 8 2 9 7 1 1 9 3 1 2 2 1 2 1 3 1 9 0 9 6 1 5 3 8 8 2 1 2 3 3 3 3 1 2 2 3 3 1 8 0 7 1 2 4 4 8 8 5 3 3 1 1 3 2 1 1 4 2 4 3 5 3 6 1 7 0 7 8 2 6 3 7 7 1 2 2 1 3 3 1 3 1 6 0 10 4 1 5 5 4 8 9 1 5 6 1 2 1 1 3 3 1 8 0 11 4 2 8 7 1 8 3 4 1 7 1 3 2 3 2 1 3 2 2 5 5 4 3 3 5 3 6 1 9 0 9 9 1 8 4 7 6 5 8 7 3 3 1 1 3 2 1 2 1 1 8 0 11 1 2 3 8 4 7 2 2 8 9 3 2 3 2 1 3 3 2 2 1 5 0 6 6 4 1 3 2 4 3 2 1 1 2 2 3 1 1 5 1 3 4 1 8 0 6 6 5 9 8 1 6 2 1 1 1 1 3 3 3 1 5 0 6 6 1 6 1 2 4 1 2 3 3 1 1 5 0 8 4 8 3 3 9 1 6 5 3 1 1 3 3 3 4 1 1 1 4 4 2 5 5 3 4 1 6 0 6 6 7 3 7 4 1 3 3 2 2 2 1 1 8 0 11 5 2 8 1 9 8 3 1 9 1 4 3 1 1 2 3 1 1 2 1 5 0 11 4 1 2 1 5 6 5 3 3 8 9 3 2 1 1 1 3 1 2 2 3 6 1 5 0 7 1 7 4 8 5 6 9 2 3 2 2 1 1 8 0 11 1 3 2 1 7 5 6 8 1 6 4 2 2 1 1 1 1 3 3 1 6 0 6 1 4 3 1 5 1 3 2 2 1 1 1 3 1 1 2 1 1 3 7 1 6 0 11 1 7 6 4 1 4 4 9 1 4 4 1 1 1 2 3 2 1 5 0 6 7 9 9 3 2 1 3 2 2 3 1 1 7 0 10 8 4 4 1 3 9 3 8 6 1 1 1 2 2 3 3 2 1 3 5 5 2 3 5 3 5 1 6 0 11 1 6 5 3 4 2 9 9 4 5 1 2 1 3 2 3 1 1 8 0 11 5 2 1 5 4 4 9 6 4 1 4 3 2 3 1 2 3 1 2 1 9 0 7 2 7 3 4 1 2 3 2 2 1 2 2 3 1 1 1 2 2 5 3 2 3 6 1 8 0 6 5 1 2 1 5 1 2 1 1 3 3 3 1 2 1 5 0 9 1 4 9 7 3 2 9 6 1 3 1 2 1 1 1 9 0 10 2 9 3 1 3 2 3 8 8 5 2 1 2 3 2 1 2 1 3 3 5 5 3 1 2 3 2 3 3 5 5 4 3 7 1 9 0 8 1 7 2 9 9 3 8 6 2 3 1 1 3 3 3 3 3 1 5 0 6 1 1 2 2 8 6 3 1 1 1 3 1 7 0 6 2 1 8 6 5 7 3 1 1 2 1 2 2 2 2 2 3 2 1 2 3 7 1 5 0 10 2 5 9 6 9 5 4 6 5 1 1 1 1 2 1 1 9 0 9 1 6 4 1 6 8 2 7 3 3 1 1 1 2 1 1 1 2 1 5 0 6 1 9 6 2 9 9 1 1 2 3 1 5 5 5 3 5 2 3 3 7 1 7 0 9 3 9 1 1 3 1 3 9 3 2 2 3 1 1 1 1 1 8 0 9 1 1 5 3 8 2 3 8 5 1 1 1 1 3 1 1 3 1 8 0 9 2 6 7 3 8 5 5 7 1 2 1 2 1 1 1 2 3 4 3 1 4 1 2 3 3 5 1 8 0 6 7 4 1 9 4 1 2 2 3 1 3 1 1 1 1 7 0 8 8 1 2 1 1 3 4 4 1 3 2 3 2 1 2 1 6 0 8 5 6 6 7 1 1 3 4 1 1 2 1 1 1 5 3 3 5 4 3 6 1 8 0 6 2 5 4 9 2 1 1 1 2 1 3 1 3 1 1 6 0 10 6 6 2 2 9 6 2 2 8 1 1 2 1 1 2 1 1 7 0 10 4 9 3 1 1 9 1 1 2 5 2 1 3 1 1 2 2 3 5 2 2 1 5 1 5 5 4 5 4 3 6 1 8 0 11 1 5 2 8 7 1 2 6 3 7 4 3 1 1 1 2 1 2 3 1 7 0 7 5 8 3 1 8 1 8 1 2 1 3 2 1 3 1 5 0 8 3 3 1 5 3 8 5 8 3 1 1 3 3 3 4 2 5 2 5 3 7 1 5 0 11 1 4 2 1 5 1 6 3 1 7 9 1 3 2 2 1 1 9 0 8 8 8 2 1 1 8 5 9 1 2 2 2 2 1 1 2 2 1 8 0 10 6 2 4 7 9 3 9 1 9 9 2 3 1 2 2 3 1 2 3 2 4 4 5 2 5 3 6 1 7 0 7 2 2 1 6 7 1 9 2 1 1 2 1 1 3 1 9 0 6 1 9 6 7 7 1 3 3 1 1 1 1 2 3 2 1 7 0 9 5 4 5 4 4 5 1 2 2 1 1 3 2 1 2 1 3 1 3 3 4 2 3 4 1 8 0 6 4 1 5 2 7 4 2 3 2 1 3 3 2 1 1 9 0 6 5 1 5 9 7 4 3 3 2 1 1 3 1 3 3 1 9 0 7 3 9 9 3 5 1 1 3 1 1 1 1 1 2 1 1 2 2 4 1 3 4 1 9 0 11 8 5 4 2 5 4 1 1 9 4 7 3 2 1 3 2 2 3 1 3 1 5 0 6 8 8 6 4 5 1 3 2 1 1 1 1 6 0 10 5 1 7 1 5 2 2 3 9 1 1 2 3 1 1 1 3 1 3 1 1 5 3 6 5 5 3 7 1 7 0 10 2 3 1 5 3 6 1 8 2 8 1 1 3 2 1 1 3 1 9 0 8 3 8 7 1 2 5 3 9 1 2 2 2 2 2 1 2 2 1 8 0 10 1 2 3 6 8 5 2 2 5 3 2 2 3 1 1 2 2 3 5 5 3 2 2 4 1 3 4 1 7 0 8 2 1 1 1 8 1 2 6 3 1 1 2 2 1 2 1 6 0 7 1 1 5 7 4 4 9 1 1 1 2 3 2 1 6 0 8 2 8 8 5 2 1 6 7 1 1 3 1 3 1 4 3 1 2 3 4 1 5 0 6 6 4 6 2 2 1 1 1 1 1 3 1 9 0 9 4 5 1 8 6 3 3 5 1 1 2 2 1 2 2 2 1 3 1 9 0 8 1 1 3 4 1 6 9 8 1 3 3 1 3 1 1 3 2 5 1 2 1 3 5 1 9 0 11 1 8 8 4 3 4 1 2 7 5 4 1 2 2 1 2 2 1 2 1 1 5 0 8 6 2 3 6 9 1 6 7 1 1 3 3 3 1 8 0 9 5 1 7 6 4 8 5 2 7 1 1 3 1 1 3 1 1 2 3 2 5 4 3 6 1 7 0 6 9 5 4 5 1 1 2 1 1 2 2 2 2 1 5 0 8 6 4 5 5 6 6 5 1 1 1 1 3 2 1 7 0 9 3 6 3 1 2 7 7 2 7 1 1 2 2 1 1 1 2 4 4 3 1 3 7 3 2 3 1 5 4 3 4 1 7 0 10 3 6 4 6 6 1 6 4 2 8 2 1 3 2 1 3 1 1 6 0 8 7 7 2 8 1 8 9 4 3 1 3 1 3 2 1 7 0 7 8 5 1 9 1 7 1 1 1 1 3 2 3 2 5 3 4 3 3 4 1 7 0 10 4 1 9 9 5 6 2 3 8 1 3 1 1 2 1 1 2 1 5 0 11 6 2 7 4 3 4 6 4 3 1 4 1 2 3 1 1 1 6 0 8 4 1 6 8 5 1 7 9 3 1 3 3 2 2 3 1 3 3 3 5 1 7 0 10 8 8 6 2 7 1 8 4 6 6 3 1 1 3 1 1 3 1 6 0 7 4 9 7 4 3 1 5 1 1 1 3 1 1 1 9 0 11 3 1 1 7 5 4 2 7 3 4 3 3 2 3 1 1 2 1 3 2 2 3 1 2 1 3 6 1 6 0 10 3 6 5 5 2 3 8 1 8 7 1 2 3 2 2 3 1 7 0 7 4 3 2 1 5 2 3 2 2 1 3 1 3 1 1 8 0 10 2 4 3 7 8 4 5 1 5 3 1 1 2 1 3 3 3 1 1 3 2 1 3 3 3 5 1 6 0 10 1 6 8 8 7 1 3 6 1 5 3 1 1 1 3 3 1 9 0 9 5 5 6 3 3 9 3 1 7 2 2 2 3 2 3 1 2 1 1 6 0 9 6 2 1 6 6 1 3 9 6 2 1 1 1 2 2 5 1 5 2 1 5 5 1 3 5 4 3 7 1 8 0 11 3 7 3 8 7 1 2 2 8 7 5 2 1 1 3 1 3 1 1 1 7 0 11 7 8 7 1 5 5 6 1 8 2 8 1 1 3 2 2 2 1 1 9 0 10 4 9 6 8 9 1 8 2 9 8 3 1 1 2 2 2 1 1 1 3 3 3 1 1 5 1 3 4 1 7 0 10 4 8 1 6 1 2 3 4 9 8 3 3 2 1 1 2 3 1 5 0 8 1 7 6 1 9 9 1 4 3 1 2 2 2 1 9 0 6 9 8 2 1 1 1 2 3 1 2 1 2 3 1 2 1 3 4 5 3 7 1 5 0 6 9 6 8 1 1 6 1 3 1 2 1 1 6 0 11 3 1 6 5 9 5 2 4 9 3 2 2 3 1 3 3 2 1 9 0 10 5 6 1 7 7 7 4 2 9 8 1 3 2 1 2 2 1 3 2 2 5 1 1 4 2 5 3 7 1 9 0 9 6 1 2 1 1 4 4 4 2 2 1 2 1 1 1 3 2 2 1 5 0 7 9 1 1 8 1 7 8 2 1 1 3 3 1 9 0 11 5 6 1 6 5 5 2 9 6 5 1 3 1 2 2 2 2 2 3 2 5 5 4 2 1 5 1 3 6 1 6 0 9 8 1 5 5 7 2 5 6 1 3 1 1 1 1 3 1 9 0 11 6 1 1 7 4 6 3 1 5 2 6 2 1 1 3 1 2 2 3 3 1 8 0 10 3 1 1 5 6 1 7 3 3 7 1 2 3 1 1 3 1 1 5 3 5 5 1 2 4 1 2 7 6 3 7 3 5 4 3 5 1 6 0 11 5 4 7 8 7 5 7 8 9 1 2 1 3 1 3 2 3 1 9 0 9 8 3 8 3 7 1 4 2 2 2 1 3 1 1 3 2 2 2 1 8 0 7 7 7 9 2 2 1 2 1 3 1 3 1 1 1 2 1 3 5 2 3 3 6 1 7 0 6 1 6 1 1 4 7 1 3 1 2 1 1 2 1 9 0 10 6 7 5 1 3 7 1 9 9 3 2 1 3 1 1 2 3 1 1 1 5 0 10 6 1 4 3 5 4 5 6 1 1 1 1 1 1 1 2 5 1 2 5 3 3 4 1 8 0 8 5 5 7 4 1 3 1 1 3 3 1 1 1 2 3 1 1 5 0 9 1 4 9 6 2 3 4 1 6 2 3 1 2 1 1 5 0 10 6 1 9 8 7 6 1 6 5 1 2 3 1 1 2 5 3 1 5 3 5 1 9 0 6 5 1 6 3 1 5 1 3 2 1 3 3 1 2 1 1 6 0 10 8 3 2 7 8 1 3 9 1 3 1 1 3 1 2 3 1 5 0 6 2 2 7 6 8 1 1 1 1 1 2 3 1 1 2 3 3 6 1 5 0 11 1 6 2 5 1 1 9 5 6 7 5 1 1 2 2 2 1 7 0 10 5 3 5 2 1 3 3 2 7 7 3 3 2 2 3 2 1 1 8 0 9 2 1 8 8 1 5 9 8 2 3 2 3 1 1 1 1 3 4 3 2 4 3 3 5 7 5 2 5 3 3 7 1 8 0 6 6 2 1 1 1 1 1 1 1 1 2 2 3 2 1 9 0 6 2 2 5 2 1 8 1 3 3 3 1 1 3 3 1 1 9 0 11 5 3 1 4 7 4 3 5 1 7 8 3 1 3 3 3 2 3 3 1 2 2 1 5 2 4 1 3 7 1 5 0 10 5 9 1 2 7 5 7 4 1 9 1 2 3 3 1 1 8 0 7 9 4 1 2 5 2 8 2 2 2 1 1 2 3 2 1 7 0 7 4 4 8 1 4 6 4 2 1 2 1 3 1 3 2 1 5 3 4 3 4 3 6 1 6 0 11 2 5 8 4 5 2 4 1 9 7 2 2 2 1 2 1 1 1 6 0 7 1 2 5 4 5 5 6 1 1 1 3 3 2 1 8 0 9 1 2 9 1 4 1 9 7 8 3 3 1 1 1 3 2 3 2 5 3 5 1 3 3 6 1 8 0 10 2 2 8 1 2 5 2 6 6 1 3 1 2 2 2 2 1 1 1 6 0 8 1 6 1 2 5 2 6 2 1 1 2 1 1 3 1 6 0 7 1 5 1 1 6 6 9 1 3 3 2 1 3 5 2 2 1 1 5 3 6 1 5 0 9 4 6 2 6 7 9 7 1 7 3 3 1 1 3 1 8 0 10 7 9 4 1 5 6 3 1 8 5 1 1 2 2 3 3 1 3 1 6 0 11 6 7 8 7 1 1 5 1 2 6 1 3 3 1 1 1 3 3 3 4 2 4 1 3 4 5 4 5 3 6 1 7 0 8 2 7 7 6 4 9 1 9 1 3 3 2 1 2 1 1 7 0 7 8 4 1 7 8 1 3 3 1 1 2 3 3 3 1 5 0 8 1 4 6 4 2 7 6 2 1 1 3 2 2 2 3 3 5 2 5 3 6 1 8 0 6 3 7 1 7 6 2 1 1 2 2 1 2 3 1 1 7 0 7 6 3 4 9 4 1 2 3 3 1 3 2 1 2 1 8 0 10 7 6 3 8 9 2 6 3 7 1 2 3 3 2 2 1 2 2 2 1 2 3 5 1 3 6 1 7 0 6 8 4 4 1 3 5 3 1 1 1 3 2 3 1 6 0 7 9 1 1 8 7 3 9 2 1 3 2 1 1 1 9 0 10 3 9 1 7 1 8 6 1 3 2 2 2 1 2 1 1 3 1 1 3 3 2 1 4 2 3 7 1 8 0 8 8 4 6 1 9 6 5 3 2 3 3 3 2 2 3 1 1 5 0 7 3 3 2 8 1 5 1 2 1 3 1 2 1 9 0 11 3 4 4 2 9 3 1 6 6 5 3 1 1 1 3 2 1 1 3 1 1 2 2 5 3 3 3 2 2 2 3 4 4 3 3 5 1 5 0 11 4 2 1 6 9 2 3 6 6 7 4 3 3 1 3 1 1 8 0 6 2 6 3 7 9 1 1 2 1 3 2 2 1 2 1 5 0 6 1 6 1 3 8 4 2 3 1 1 2 2 1 1 3 4 3 7 1 5 0 10 2 8 1 2 1 9 3 6 8 5 3 1 1 3 1 1 9 0 11 8 9 3 6 7 4 5 4 3 4 1 1 1 2 2 1 1 2 3 1 1 9 0 8 5 9 9 4 1 5 2 1 2 3 1 2 2 1 1 1 2 2 5 4 5 3 2 2 3 6 1 7 0 9 8 3 1 1 9 7 1 1 3 3 1 1 3 2 2 1 1 5 0 8 6 6 9 6 1 6 1 9 2 1 2 3 2 1 9 0 7 7 6 9 2 4 1 5 1 2 3 3 2 3 1 1 2 1 5 1 2 1 2 3 4 1 8 0 7 2 1 1 1 4 2 8 3 1 2 1 1 1 1 1 1 7 0 6 4 1 5 7 7 3 2 1 3 1 1 3 1 1 7 0 6 9 1 7 2 5 2 2 1 3 2 1 1 3 3 1 3 1 2 4 2 4 3 3 5 1 8 0 10 1 7 9 4 1 5 5 9 5 1 1 3 1 2 1 2 1 2 1 9 0 9 7 8 1 4 9 4 2 6 6 1 2 2 3 1 1 1 3 3 1 7 0 8 8 6 4 8 7 2 1 9 3 1 3 1 1 1 1 3 4 5 3 5 3 4 1 6 0 7 8 4 7 7 1 1 1 3 2 3 1 3 1 1 6 0 10 6 4 4 1 3 5 4 1 6 4 1 1 3 1 1 1 1 7 0 7 5 6 7 6 1 8 1 1 2 2 2 2 3 1 2 1 4 2 3 6 1 8 0 7 3 7 7 4 4 8 1 1 2 3 3 1 3 1 2 1 9 0 8 7 3 1 8 3 4 5 4 1 3 3 1 3 2 2 1 2 1 8 0 7 1 4 1 2 1 1 8 1 1 3 3 1 1 2 3 3 2 1 5 4 1 3 6 1 5 0 7 9 6 5 1 6 3 4 3 3 2 1 1 1 7 0 6 9 9 1 9 2 8 1 1 2 2 1 3 1 1 8 0 7 4 3 1 1 7 5 8 1 2 3 3 1 3 2 1 1 2 1 1 3 5 3 2 5 5 5 3 7 1 8 0 8 4 1 4 7 8 8 6 8 3 3 1 1 1 1 1 3 1 8 0 11 6 8 7 6 9 9 5 2 1 3 6 1 2 3 3 1 2 1 1 1 9 0 8 9 1 4 5 2 3 5 4 2 3 3 1 2 2 1 1 1 2 1 3 1 4 3 5 3 4 1 8 0 10 1 1 4 6 5 9 9 7 4 2 2 1 3 1 3 3 1 1 1 8 0 11 9 1 5 8 7 2 9 4 2 5 9 1 3 2 2 1 3 1 3 1 9 0 10 4 5 2 7 4 9 1 9 7 8 2 1 1 1 2 2 2 2 1 2 1 1 1 3 4 1 5 0 7 6 4 9 6 1 2 1 2 1 1 1 3 1 6 0 9 9 4 3 2 1 5 3 2 4 1 1 1 3 1 3 1 8 0 7 9 3 5 7 8 1 9 2 2 3 3 1 1 1 2 5 2 4 4 3 4 1 6 0 6 6 1 8 6 1 1 3 1 3 3 3 3 1 7 0 9 5 6 3 1 3 9 9 1 6 1 3 1 3 1 2 3 1 5 0 7 3 3 4 1 4 5 1 3 3 2 3 1 3 2 3 2 3 6 1 9 0 8 9 7 2 4 2 1 6 1 1 2 1 2 1 2 3 2 3 1 9 0 11 9 4 1 6 4 3 5 6 1 7 1 3 1 1 3 1 2 3 3 1 1 9 0 10 7 9 5 7 8 5 8 9 7 1 3 3 2 1 1 2 3 1 3 1 2 4 5 2 2 4 5 7 6 1 5 5 3 7 1 5 0 10 3 3 7 1 7 1 4 4 5 8 3 1 2 2 2 1 7 0 8 2 6 6 1 7 4 6 4 1 2 1 1 2 3 3 1 8 0 9 7 1 9 5 1 8 3 6 7 2 2 1 3 3 3 3 2 3 3 3 1 4 2 3 3 6 1 6 0 10 7 1 1 6 3 8 2 4 3 2 1 3 1 3 3 2 1 6 0 9 8 1 5 5 4 1 1 6 4 1 2 1 3 3 1 1 8 0 7 1 8 2 6 4 1 1 1 2 2 1 1 2 1 3 2 2 1 1 5 4 3 4 1 8 0 6 4 1 7 8 8 6 1 3 2 3 2 2 1 1 1 6 0 7 8 4 7 8 2 1 8 1 1 1 3 1 2 1 7 0 10 8 4 3 9 4 1 2 4 2 8 1 1 2 3 2 1 3 4 3 4 3 3 6 1 9 0 8 3 5 1 2 1 4 4 3 2 1 2 3 2 2 2 2 1 1 9 0 7 3 7 1 4 9 1 1 1 3 3 2 2 1 2 2 3 1 5 0 11 9 1 3 4 7 3 2 2 2 7 5 1 2 3 2 1 3 1 3 4 3 3 3 6 1 6 0 9 2 1 3 7 8 5 6 4 3 1 2 1 3 1 1 1 8 0 8 4 1 1 4 5 1 6 8 1 1 1 1 2 2 2 2 1 5 0 7 1 6 3 7 1 2 8 1 3 2 1 1 5 2 2 3 2 2 4 1 5 5 3 2 8 6 6 3 5 3 3 7 1 5 0 8 6 8 5 2 9 6 1 5 2 1 2 2 3 1 6 0 11 7 4 4 9 5 1 7 9 1 4 1 3 3 3 1 1 1 1 8 0 10 8 8 5 3 1 8 2 7 1 9 1 2 2 1 1 3 1 3 2 2 2 5 1 5 1 3 6 1 8 0 9 4 8 7 9 4 1 4 8 1 1 1 1 3 3 1 3 2 1 9 0 9 4 5 8 1 1 9 2 4 1 3 1 1 3 1 1 2 3 1 1 5 0 11 3 1 1 6 7 1 6 6 4 8 9 1 1 1 1 3 5 1 1 5 3 1 3 4 1 9 0 10 7 3 2 1 6 2 9 5 6 3 3 1 2 1 1 2 3 3 1 1 8 0 9 1 5 4 9 9 8 6 2 5 2 1 2 2 1 3 1 1 1 9 0 8 1 4 4 1 1 2 4 1 1 2 2 1 1 1 3 3 2 5 4 4 3 3 4 1 8 0 8 3 3 7 1 1 1 8 6 2 1 1 1 3 2 1 3 1 6 0 6 1 6 2 5 4 3 1 2 3 3 1 1 1 5 0 7 4 1 2 1 8 6 6 2 1 3 1 3 3 2 1 3 3 5 1 7 0 9 1 1 9 3 4 2 6 8 2 3 1 3 2 1 1 2 1 9 0 8 8 2 7 1 7 5 2 1 1 1 1 2 2 1 1 3 1 1 9 0 9 8 7 1 9 5 1 6 2 2 3 2 1 1 2 1 3 1 1 3 3 3 5 3 6 5 3 5 4 3 5 1 7 0 7 5 1 8 7 3 3 5 1 1 3 1 1 1 2 1 8 0 10 1 1 2 7 6 5 5 2 1 6 2 3 2 1 2 3 3 1 1 5 0 8 9 7 1 7 4 6 1 9 2 3 3 1 3 4 3 2 2 5 3 7 1 7 0 6 1 2 1 2 8 3 3 3 2 2 1 2 1 1 7 0 8 5 9 4 5 5 3 1 1 3 3 3 1 2 2 1 1 7 0 7 9 5 8 2 1 3 4 1 1 1 1 1 2 1 4 4 3 2 1 2 4 3 4 1 8 0 7 1 1 5 3 7 4 7 1 2 2 3 1 2 1 3 1 7 0 6 3 8 1 6 9 8 3 2 2 3 3 1 2 1 7 0 10 7 1 4 1 8 6 8 5 3 8 3 2 2 3 2 2 1 2 5 5 1 3 5 1 6 0 11 1 7 3 5 1 5 4 6 7 5 6 2 2 1 2 3 1 1 7 0 10 6 8 3 9 1 3 3 9 3 8 1 2 3 2 1 1 3 1 6 0 7 6 5 7 9 5 1 2 3 3 1 2 3 2 5 1 2 2 1 3 4 1 6 0 9 4 7 4 4 8 8 1 7 6 2 1 2 2 2 2 1 8 0 10 7 1 1 1 4 6 4 4 6 9 1 2 3 1 3 1 3 3 1 8 0 6 5 5 1 1 2 9 3 3 1 2 1 1 2 3 3 3 3 3 4 4 2 1 5 4 3 7 1 9 0 11 1 6 3 9 8 7 1 4 4 7 2 2 3 3 1 1 1 1 1 3 1 9 0 9 9 5 1 5 3 1 5 8 3 2 1 2 1 3 3 1 1 1 1 6 0 9 7 1 7 8 8 2 7 9 8 1 1 3 3 1 1 4 1 4 3 2 3 4 3 5 1 7 0 9 7 3 7 1 7 6 8 7 7 1 2 1 2 3 1 1 1 7 0 6 1 8 6 2 2 9 1 1 1 1 3 2 1 1 6 0 9 1 8 9 8 7 2 3 1 6 2 2 1 1 1 3 4 5 2 3 5 3 5 1 5 0 11 4 5 1 2 8 1 5 7 3 7 9 2 2 1 3 2 1 9 0 9 3 9 2 4 6 9 1 8 2 1 3 1 2 2 3 3 2 2 1 7 0 10 5 8 8 7 6 8 7 8 1 8 3 1 1 1 1 3 1 1 2 5 2 1 3 6 1 9 0 8 7 1 6 8 1 7 1 1 1 3 3 1 2 1 1 2 3 1 6 0 7 8 3 3 7 1 2 6 1 1 1 1 3 1 1 9 0 9 3 3 8 3 5 2 8 1 7 1 2 3 3 3 3 3 2 2 2 4 4 3 5 5 3 7 1 7 0 8 4 1 3 8 8 4 4 3 2 2 2 3 1 1 1 1 6 0 7 6 2 2 1 8 7 1 1 2 1 2 3 2 1 9 0 9 7 2 4 7 1 1 8 2 2 2 3 1 1 1 1 2 3 1 5 5 4 2 5 1 2 1 2 6 5 4 3 3 4 1 9 0 6 1 2 3 4 4 9 1 3 1 1 3 2 2 2 1 1 5 0 9 6 5 1 6 4 9 9 5 1 3 2 2 2 1 1 7 0 9 7 9 5 7 4 1 9 3 2 1 2 2 3 1 2 3 3 3 2 3 3 7 1 5 0 8 1 8 6 1 7 7 1 3 3 1 1 3 1 1 7 0 6 6 1 6 4 7 3 3 1 1 1 3 1 1 1 9 0 11 1 6 6 1 1 4 9 5 1 8 4 1 1 1 2 1 1 2 1 3 1 4 4 3 2 3 1 3 6 1 8 0 10 7 8 8 1 8 5 2 4 9 6 3 1 3 1 1 1 3 1 1 5 0 11 4 2 7 3 1 5 4 4 5 4 8 2 3 1 3 1 1 6 0 7 5 1 8 7 5 9 6 3 2 2 3 3 1 1 5 3 1 1 1 3 7 1 8 0 7 6 8 1 7 1 5 7 2 2 2 1 1 1 3 1 1 6 0 11 9 5 5 7 6 7 1 9 7 1 1 3 3 1 3 1 2 1 7 0 10 7 8 6 8 4 4 7 2 8 1 1 2 1 1 1 2 2 4 1 3 2 3 3 1 1 6 6 5 4 3 6 1 8 0 7 5 1 7 2 8 9 2 2 3 1 1 2 2 3 1 1 9 0 11 1 8 1 7 7 8 7 1 4 4 7 1 3 2 1 3 1 3 3 3 1 8 0 6 6 1 8 8 9 5 1 2 1 2 2 1 3 1 4 1 3 5 5 3 3 7 1 6 0 11 8 8 8 2 1 5 4 5 3 3 7 1 1 1 2 2 1 1 5 0 6 8 9 2 1 7 2 3 3 1 1 3 1 8 0 11 5 3 3 6 9 1 7 6 6 9 9 1 2 2 1 1 1 1 2 5 2 5 5 1 1 1 3 7 1 6 0 8 6 6 1 9 8 1 9 5 3 3 1 2 1 3 1 8 0 11 9 1 1 5 8 1 9 6 2 2 7 1 3 1 3 1 1 1 1 1 5 0 10 8 9 6 1 9 2 6 6 1 1 3 1 3 1 1 1 5 3 3 1 5 1 3 5 1 7 0 9 1 1 4 8 1 4 5 8 1 3 1 3 1 1 1 3 1 9 0 11 1 1 9 4 1 2 6 5 4 2 4 3 3 3 3 1 3 2 2 1 1 7 0 9 5 1 2 5 4 1 9 5 6 2 1 3 1 2 1 1 3 4 2 1 3 3 5 1 6 0 6 9 9 8 3 1 2 1 3 3 3 2 3 1 6 0 11 1 1 6 4 1 5 8 1 3 3 3 1 2 2 2 3 1 1 7 0 11 6 4 8 1 5 2 8 1 2 1 2 2 2 2 1 3 3 1 1 3 3 1 5 4 4 6 3 5 4 3 5 1 7 0 6 1 1 1 4 6 6 1 2 2 2 1 3 3 1 7 0 7 8 1 6 4 8 7 9 2 1 1 1 3 3 2 1 6 0 11 9 9 1 6 9 5 8 1 6 1 9 2 3 3 1 2 1 3 4 1 5 4 3 5 1 6 0 7 2 3 9 3 7 1 5 1 1 2 3 1 2 1 9 0 9 4 2 7 8 9 1 7 5 1 3 2 3 3 1 2 1 3 3 1 5 0 7 6 1 2 8 4 7 7 1 3 1 3 2 5 2 1 5 3 3 7 1 8 0 9 6 4 8 9 1 7 1 6 1 1 1 3 3 1 2 1 1 1 5 0 11 4 1 2 2 5 3 8 1 7 6 6 2 2 1 1 2 1 7 0 6 1 9 9 2 5 7 2 2 2 1 1 3 2 4 4 4 5 5 1 5 3 6 1 6 0 11 2 5 1 1 1 2 9 4 1 5 2 2 1 1 1 3 1 1 7 0 11 8 1 7 3 7 6 6 2 9 5 1 1 2 1 1 3 3 1 1 5 0 6 9 4 1 8 4 6 3 1 3 2 3 3 2 2 2 1 1 3 5 1 9 0 10 1 1 8 1 3 9 3 7 4 4 2 2 2 3 2 1 3 2 1 1 8 0 9 3 6 1 1 1 9 7 3 1 1 3 1 1 3 1 1 1 1 7 0 8 9 8 1 5 9 3 9 5 3 1 3 3 3 1 3 5 1 4 5 5 2 6 3 1 2 4 1 7 3 4 5 3 5 1 9 0 11 9 7 2 7 3 1 8 7 9 7 4 2 2 1 2 3 3 3 1 1 1 5 0 7 1 3 3 5 6 7 1 3 3 1 3 3 1 8 0 8 5 1 9 5 3 6 4 4 3 3 3 2 1 2 1 1 1 4 1 3 3 3 6 1 6 0 10 8 3 2 5 9 7 8 1 1 4 2 2 1 1 1 1 1 7 0 11 4 3 5 1 4 9 6 6 1 5 5 3 2 1 2 1 1 1 1 8 0 6 9 2 6 1 3 3 1 3 3 2 2 3 2 1 4 4 4 5 3 5 3 5 1 5 0 11 5 9 8 3 9 3 1 4 7 6 1 2 1 2 1 1 1 5 0 6 1 7 4 9 6 7 3 2 1 3 1 1 6 0 6 9 5 1 2 6 4 1 1 1 1 1 1 2 2 5 2 3 3 6 1 9 0 6 3 5 4 1 8 3 2 3 1 1 1 1 1 3 1 1 6 0 9 2 6 7 1 4 8 7 9 2 1 1 3 2 1 2 1 6 0 11 4 7 8 3 2 4 5 6 4 2 1 3 2 1 1 1 3 1 2 5 5 2 5 2 2 2 4 1 5 5 3 5 1 9 0 6 8 9 1 9 3 1 2 3 1 3 1 2 1 1 2 1 6 0 8 9 1 2 7 6 1 1 7 3 2 1 2 1 3 1 8 0 7 1 8 8 5 9 3 2 2 2 1 1 3 3 1 2 5 5 2 3 1 3 6 1 5 0 10 1 4 1 7 6 2 9 2 3 5 3 3 3 3 1 1 9 0 10 8 2 2 7 5 1 4 2 3 2 2 2 2 1 1 2 2 1 1 1 6 0 11 3 6 9 1 7 8 5 9 1 1 9 3 2 1 2 2 1 1 2 4 2 4 4 3 4 1 9 0 7 4 9 8 1 2 5 6 1 1 2 3 3 1 3 2 2 1 9 0 8 6 3 1 8 9 1 3 7 2 1 1 2 1 3 1 1 1 1 8 0 6 1 9 4 4 8 3 2 3 3 1 1 1 2 1 2 3 2 1 3 5 1 5 0 11 8 3 3 5 6 2 9 5 1 8 2 3 2 1 1 2 1 6 0 9 1 1 2 7 4 9 5 4 4 3 2 2 1 1 2 1 7 0 7 4 1 1 8 9 9 4 3 2 2 3 1 1 1 4 3 5 4 3 3 6 1 7 0 6 2 2 6 9 7 1 2 1 2 1 2 3 1 1 5 0 8 9 1 8 1 1 2 1 1 2 1 3 3 1 1 9 0 8 7 9 1 1 7 2 7 3 1 2 1 2 3 3 2 3 2 1 4 4 2 1 2 5 3 6 1 5 4 5 3 5 1 7 0 6 1 9 6 6 9 6 3 2 3 1 3 2 1 1 6 0 9 3 1 3 1 2 4 6 6 8 2 1 3 2 1 2 1 8 0 6 9 1 9 7 3 6 1 1 3 1 1 2 1 3 5 5 5 5 3 3 7 1 6 0 11 6 6 5 1 4 3 8 7 1 4 6 1 1 3 2 3 1 1 9 0 7 5 7 1 9 4 5 4 1 1 2 2 1 1 2 3 3 1 9 0 7 6 7 3 5 1 6 6 1 3 1 3 2 2 1 3 3 5 5 1 1 1 2 3 3 7 1 9 0 8 1 2 6 5 3 1 5 9 3 1 3 2 2 2 1 3 1 1 7 0 10 1 1 9 3 1 7 1 4 3 8 3 1 1 2 1 1 2 1 7 0 6 1 6 5 3 5 1 3 1 3 1 3 1 1 2 2 2 3 3 5 3 3 7 1 7 0 9 4 8 6 6 7 1 8 2 4 1 2 3 2 1 1 1 1 6 0 7 7 4 1 7 9 7 3 1 1 2 2 1 1 1 7 0 9 1 4 7 5 3 9 6 5 5 2 2 2 3 3 3 1 4 3 3 4 4 2 2 3 3 5 1 6 5 3 3 7 1 5 0 9 3 2 4 1 1 4 3 6 3 2 1 2 1 1 1 8 0 6 1 6 1 3 1 9 1 2 3 2 3 3 1 2 1 9 0 7 2 4 1 3 5 7 1 3 3 2 2 3 1 3 2 1 1 3 2 5 1 3 1 3 6 1 8 0 11 2 9 1 1 7 4 6 5 3 4 9 1 3 3 2 1 1 3 3 1 9 0 10 9 1 2 5 1 2 3 5 3 8 1 1 1 2 1 1 2 1 3 1 7 0 9 6 1 5 8 9 3 3 3 9 3 3 1 3 2 1 1 4 3 2 1 5 3 3 7 1 9 0 10 1 1 1 5 7 4 1 1 9 1 1 2 3 1 1 1 3 1 2 1 8 0 6 4 7 9 8 1 9 2 3 1 1 1 2 1 3 1 7 0 9 9 8 5 7 9 5 1 5 4 1 2 3 1 3 2 2 2 1 4 4 1 3 3 3 6 1 8 0 11 2 7 5 9 2 2 3 1 4 8 4 3 3 3 2 1 3 3 1 1 5 0 8 5 1 2 9 6 4 4 6 1 2 2 1 1 1 8 0 6 8 1 7 4 8 9 1 2 2 3 3 3 2 3 4 1 1 4 2 1 3 6 1 8 0 11 4 3 8 7 2 7 1 3 9 2 1 1 1 1 3 3 3 1 3 1 5 0 8 8 7 9 1 5 5 1 7 3 2 1 1 1 1 6 0 6 6 1 9 2 4 5 2 1 1 1 1 3 4 1 1 3 4 5 2 3 2 4 5 3 4 1 7 0 6 3 3 1 9 7 9 2 1 2 2 1 1 1 1 8 0 7 6 9 9 9 1 2 1 2 1 3 3 3 3 1 3 1 9 0 11 9 4 1 2 1 9 7 6 4 9 1 3 1 2 2 1 3 2 3 1 1 5 3 2 3 4 1 7 0 10 1 2 7 4 6 1 9 1 1 4 3 1 2 3 3 1 1 1 9 0 8 6 9 3 4 1 6 8 8 2 1 2 3 1 2 2 3 1 1 5 0 10 1 9 3 1 6 2 1 3 1 2 1 3 3 2 1 2 4 2 3 3 4 1 7 0 9 3 9 5 4 8 9 6 8 1 1 1 2 3 1 3 1 1 5 0 9 2 9 7 6 2 9 1 4 2 2 1 2 1 3 1 8 0 7 6 5 2 5 4 9 1 1 2 1 3 2 2 2 1 5 1 4 5 3 5 1 5 0 7 1 9 2 8 7 5 9 1 1 2 2 1 1 9 0 10 1 5 7 6 9 7 6 9 6 9 1 1 1 3 3 3 1 2 2 1 7 0 10 4 3 2 7 1 8 9 1 3 3 1 3 1 1 2 3 1 1 3 4 4 5 3 3 6 1 6 4 3 3 6 1 7 0 8 5 1 8 6 1 4 4 9 1 1 2 1 2 2 2 1 8 0 6 2 1 2 1 5 6 1 1 2 2 2 3 2 3 1 7 0 10 6 4 8 8 4 8 2 5 3 1 1 1 1 1 3 2 3 2 2 1 2 3 1 3 4 1 5 0 9 4 4 7 1 4 1 8 2 7 1 3 3 1 1 1 7 0 10 9 7 3 8 9 8 3 7 6 1 1 3 2 1 1 1 2 1 7 0 8 5 9 3 8 9 1 3 7 1 3 1 1 1 3 1 5 3 1 3 3 6 1 5 0 6 4 6 4 2 1 9 2 3 1 2 3 1 8 0 8 2 8 6 2 1 6 2 9 2 1 1 3 2 1 3 3 1 9 0 11 9 4 7 8 1 6 7 2 7 6 6 2 1 1 3 1 2 2 1 2 4 3 1 5 1 2 3 5 1 8 0 9 8 1 8 6 9 2 7 9 2 1 3 2 1 1 1 3 3 1 5 0 10 9 3 3 5 3 1 7 1 6 2 3 1 1 2 1 1 5 0 7 7 3 3 2 6 1 1 3 3 1 1 2 2 2 5 4 5 1 4 6 4 4 3 4 1 5 0 8 9 7 1 6 2 6 4 8 2 3 3 3 1 1 8 0 11 1 1 4 3 4 4 7 2 2 8 1 1 1 3 1 1 3 3 1 1 6 0 6 5 1 1 6 1 9 1 2 3 2 1 1 2 4 3 3 3 7 1 6 0 6 1 5 8 1 9 4 3 1 2 1 1 1 1 6 0 8 3 3 8 6 9 1 6 8 3 1 1 1 3 1 1 6 0 7 4 5 3 1 6 1 6 2 3 1 3 2 2 2 2 4 5 2 3 5 3 4 1 9 0 7 8 1 6 2 6 4 3 1 1 2 2 1 2 3 2 2 1 9 0 9 5 2 1 6 1 5 6 1 2 1 1 1 1 2 2 2 1 1 1 6 0 6 4 1 2 9 1 2 1 2 2 3 2 1 3 5 3 2 3 4 1 8 0 11 7 1 3 1 7 9 3 8 1 4 6 2 1 1 2 2 2 1 3 1 8 0 9 5 3 1 8 9 3 9 6 9 1 2 3 3 1 2 3 1 1 9 0 7 2 1 2 5 9 7 3 3 1 2 3 2 1 3 2 2 5 3 4 3 5 5 2 5 1 9 7 6 3 5 4 3 4 1 9 0 6 4 4 5 3 1 6 2 1 1 1 1 1 1 1 2 1 8 0 8 8 9 7 3 8 1 5 2 1 1 2 1 3 1 2 3 1 9 0 10 9 6 2 2 9 1 5 8 7 1 2 1 2 3 2 1 3 3 1 1 1 5 4 3 6 1 9 0 6 3 2 1 7 5 9 3 1 1 1 1 2 1 2 3 1 8 0 6 1 7 4 7 2 9 1 3 3 2 1 3 1 1 1 5 0 9 3 1 5 8 1 9 3 4 8 3 3 2 1 1 1 5 1 3 4 1 3 4 1 6 0 10 2 3 8 1 8 1 5 5 7 4 1 2 3 3 3 1 1 5 0 10 6 8 4 6 4 1 3 8 8 1 3 2 3 3 1 1 5 0 9 1 6 6 3 7 9 2 6 1 1 1 1 3 1 1 3 2 5 3 5 1 9 0 7 1 6 3 8 6 2 4 2 1 1 1 3 1 2 3 2 1 7 0 9 2 7 6 1 1 1 7 7 1 2 1 1 1 1 1 2 1 5 0 10 7 9 9 7 6 1 9 1 6 3 3 1 1 1 1 2 2 5 2 1 3 6 1 9 0 11 1 6 2 7 5 1 1 2 5 4 4 1 1 1 1 1 2 2 1 2 1 9 0 10 7 4 7 1 5 7 3 6 3 4 1 2 1 3 1 1 2 1 3 1 6 0 7 5 1 2 3 2 8 6 3 1 2 2 3 3 5 1 1 1 4 5 5 1 2 7 5 4 3 4 1 5 0 9 4 1 5 3 8 2 7 9 8 1 1 1 2 3 1 9 0 7 1 4 1 6 1 5 9 1 3 3 2 2 3 3 3 2 1 9 0 9 6 8 1 5 7 5 8 2 4 2 2 3 3 1 2 2 1 1 5 5 2 1 3 7 1 9 0 7 7 9 3 1 1 3 2 2 1 1 3 2 3 2 2 3 1 8 0 10 8 3 6 5 1 3 5 5 2 2 2 2 3 1 3 1 1 3 1 9 0 6 6 1 7 7 3 2 1 2 1 3 1 2 1 1 1 4 2 3 3 3 2 3 3 5 1 5 0 8 1 8 1 1 1 5 2 8 1 3 2 1 3 1 5 0 9 5 1 1 6 7 3 8 1 9 1 2 2 2 3 1 5 0 9 6 1 1 2 3 6 7 4 9 3 1 2 2 1 5 1 5 2 3 3 7 1 9 0 9 1 8 7 6 5 4 5 1 6 3 3 3 2 1 1 1 2 3 1 6 0 7 6 9 3 3 1 7 1 1 1 1 3 2 1 1 9 0 11 4 6 4 8 3 6 7 1 2 3 3 2 2 3 3 2 3 3 1 2 1 4 2 4 5 2 4 3 5 1 5 0 7 6 1 9 6 6 7 7 2 2 1 1 1 1 9 0 6 1 2 2 3 7 5 3 1 1 3 3 1 2 1 1 1 5 0 8 3 7 4 6 2 7 1 1 2 2 1 1 1 5 4 1 4 2 7 4 6 1 4 5 3 5 1 6 0 9 9 5 2 5 2 2 4 1 1 1 3 2 2 3 1 1 9 0 6 4 1 7 2 1 3 2 2 3 3 1 2 3 1 2 1 8 0 7 7 6 1 8 4 1 9 2 1 2 2 3 3 1 3 2 3 4 5 4 3 7 1 8 0 10 8 6 1 7 8 2 5 8 9 5 3 1 3 3 1 1 1 2 1 8 0 11 6 2 4 4 8 3 2 9 9 8 1 1 1 1 1 2 3 3 3 1 6 0 11 1 5 2 4 8 1 8 6 1 2 7 3 1 2 1 1 3 3 3 5 5 5 1 4 3 4 1 5 0 7 3 3 3 7 2 1 1 3 2 1 2 1 1 8 0 8 1 4 2 7 6 7 6 1 1 1 2 2 3 3 1 2 1 8 0 7 1 4 8 5 4 7 9 1 2 3 2 3 1 3 2 5 5 5 1 3 5 1 8 0 9 4 9 1 4 1 9 3 9 9 1 3 3 1 2 2 1 3 1 6 0 7 9 1 7 6 5 1 7 1 1 1 2 1 3 1 9 0 10 6 1 8 7 6 5 2 7 3 9 2 1 2 2 1 1 3 3 1 2 2 5 2 1 4 6 3 3 2 4 5 3 4 1 7 0 6 5 9 7 2 4 1 1 2 1 1 2 3 1 1 9 0 10 4 7 6 8 1 2 3 8 1 6 1 1 1 3 3 3 1 1 2 1 5 0 9 5 2 1 6 5 6 4 8 9 2 1 1 2 2 5 4 2 3 3 6 1 6 0 8 1 7 6 7 3 3 3 2 3 2 1 1 2 2 1 8 0 8 2 9 1 6 3 5 1 3 1 2 3 1 2 1 1 1 1 7 0 6 7 6 7 4 1 1 3 3 1 3 2 3 2 4 4 3 1 5 3 3 7 1 6 0 10 7 3 4 5 7 6 8 1 2 1 2 1 3 3 1 1 1 7 0 10 9 6 9 6 6 6 1 4 2 7 2 2 2 1 3 2 2 1 6 0 10 8 8 3 5 4 9 2 5 3 1 2 2 2 1 1 1 2 1 1 2 2 2 1 3 6 1 6 0 8 4 6 1 4 5 4 1 5 3 2 1 2 1 3 1 7 0 6 8 5 1 9 6 8 3 1 2 1 2 1 3 1 6 0 10 1 7 3 5 1 8 2 4 5 5 2 3 2 1 1 3 4 4 5 2 5 4 3 3 5 2 4 5 5 3 4 1 7 0 11 6 2 2 5 2 8 3 9 8 1 7 2 1 1 3 3 1 2 1 8 0 9 3 1 5 1 3 4 9 3 5 3 3 2 3 1 1 3 3 1 8 0 10 5 7 6 4 1 2 2 4 8 7 3 3 3 3 1 2 3 2 5 3 3 4 3 4 1 5 0 10 8 2 5 1 9 1 4 3 3 5 1 1 1 3 3 1 7 0 7 8 2 4 1 8 4 7 3 2 3 1 2 2 3 1 5 0 6 9 4 1 7 2 1 1 1 3 2 2 5 1 2 1 3 4 1 7 0 6 9 1 7 4 3 2 3 3 1 2 1 1 1 1 7 0 6 2 7 3 1 1 5 3 1 1 3 3 1 1 1 9 0 10 7 3 1 1 6 9 3 3 2 8 1 3 2 2 2 3 3 1 2 1 5 4 1 3 7 1 9 0 7 7 1 7 7 2 1 2 1 3 3 3 1 2 3 3 1 1 6 0 7 4 4 1 5 2 4 9 2 3 1 2 2 1 1 6 0 11 3 6 2 1 9 3 6 2 3 2 5 3 2 2 3 2 1 4 1 3 3 1 1 1 3 5 1 8 0 9 5 1 5 9 6 7 8 7 7 3 3 3 2 1 2 1 2 1 8 0 11 1 3 8 1 7 5 4 7 8 8 6 1 3 3 1 1 1 2 1 1 6 0 7 2 8 5 1 6 5 7 1 2 2 1 3 3 1 4 3 4 5 3 7 4 1 7 5 3 3 4 1 5 0 6 3 4 3 1 4 2 1 1 2 1 1 1 5 0 11 1 7 2 1 2 8 8 5 4 3 9 1 1 2 2 3 1 5 0 9 1 4 9 1 2 3 8 6 9 1 2 1 2 1 3 5 1 2 3 5 1 7 0 10 8 9 7 1 3 4 9 4 2 2 3 1 3 1 2 1 2 1 7 0 6 8 6 6 1 5 5 2 3 1 1 2 3 2 1 9 0 8 3 9 1 8 7 4 9 1 1 3 1 2 2 3 1 3 3 3 5 2 1 2 3 4 1 8 0 10 6 4 5 2 7 9 3 1 1 4 1 3 1 1 1 1 2 1 1 6 0 8 3 1 2 3 1 5 3 9 2 2 1 1 3 3 1 5 0 9 3 6 1 8 4 8 9 9 4 3 2 2 1 1 1 5 2 4 3 6 1 9 0 11 1 9 1 1 5 6 9 2 7 6 4 3 2 3 2 2 2 1 1 1 1 5 0 10 4 8 1 2 3 6 7 3 3 1 1 2 3 3 1 1 9 0 11 7 7 6 7 2 1 8 9 7 5 1 2 3 3 1 2 1 1 3 2 2 4 5 5 4 1 3 4 1 9 0 10 7 7 7 4 1 3 2 8 6 3 1 1 1 1 3 1 1 3 3 1 8 0 11 9 3 6 1 8 4 2 4 9 5 1 2 1 1 3 1 2 2 1 1 8 0 7 3 2 2 3 8 7 1 1 1 1 1 3 1 2 3 4 5 2 4 5 3 4 1 1 4 7 2 5 4 3 7 1 9 0 10 4 9 1 9 4 8 1 2 9 4 3 1 3 1 2 1 1 2 2 1 8 0 10 5 4 6 8 3 7 3 1 5 3 1 3 2 2 3 1 3 2 1 5 0 6 1 9 8 3 9 6 3 3 2 1 1 2 4 1 2 3 4 1 3 5 1 7 0 8 8 5 6 1 2 8 6 1 3 1 1 1 2 1 3 1 6 0 8 5 3 1 8 6 8 5 7 3 1 3 2 1 1 1 6 0 8 2 8 3 1 2 5 5 8 2 3 2 1 2 2 5 2 4 1 2 3 7 1 8 0 11 9 7 2 7 8 8 4 1 2 3 6 1 3 2 3 2 1 1 3 1 8 0 9 1 1 3 2 8 8 2 2 4 2 1 2 3 3 2 3 2 1 8 0 10 1 1 3 1 6 7 4 1 5 4 1 2 1 3 3 1 1 1 3 3 2 2 2 2 4 3 4 1 5 0 7 1 4 9 7 5 8 6 1 3 1 3 1 1 5 0 10 5 4 7 8 1 7 8 7 1 2 1 3 2 1 3 1 8 0 7 4 9 1 1 1 6 2 3 2 2 3 2 3 1 1 3 2 5 2 3 5 1 8 0 7 1 1 2 1 6 3 3 3 1 3 3 1 1 1 3 1 8 0 6 5 6 7 1 2 5 3 1 3 1 3 1 1 2 1 9 0 11 6 3 8 9 8 4 9 9 3 1 8 1 3 2 3 1 3 3 1 3 4 3 1 1 2 6 7 5 1 5 4 3 4 1 7 0 9 3 5 9 3 1 4 2 9 9 2 1 1 1 3 2 3 1 6 0 9 6 1 5 6 8 4 1 9 7 2 3 3 3 2 1 1 8 0 6 1 3 3 8 3 3 1 3 2 1 1 3 3 3 1 1 1 2 3 6 1 6 0 11 9 1 5 2 4 1 2 1 7 5 7 1 1 3 1 3 1 1 6 0 10 1 8 7 4 5 6 8 9 2 8 3 1 1 2 1 3 1 6 0 6 4 9 1 2 1 9 2 2 2 1 3 3 5 1 3 2 3 4 3 4 1 8 0 10 3 7 9 2 8 2 7 8 1 4 1 1 3 1 2 1 2 3 1 8 0 10 6 1 3 6 7 1 1 4 4 8 2 3 2 1 1 3 2 3 1 9 0 11 7 1 8 2 1 4 6 4 5 4 8 3 1 3 2 1 2 2 1 2 1 4 5 3 3 5 1 6 0 8 2 2 3 7 1 9 4 5 3 1 2 3 3 1 1 7 0 10 5 7 8 4 4 7 5 7 1 2 3 1 3 1 1 3 2 1 8 0 9 2 2 1 2 5 1 1 8 6 3 2 3 1 2 3 2 1 3 1 3 5 3 3 5 1 7 0 7 1 6 3 2 2 3 9 2 2 3 2 1 3 1 1 8 0 6 7 7 6 1 9 3 2 3 2 1 3 1 3 1 1 5 0 10 3 6 7 6 5 1 4 1 4 6 1 3 1 3 1 2 4 3 5 1 2 4 7 5 5 4 3 6 1 6 0 9 6 1 1 7 1 6 7 6 8 1 2 2 2 2 2 1 5 0 10 1 6 3 4 1 8 2 4 3 1 3 2 3 3 1 1 8 0 8 8 8 4 1 8 4 9 6 3 2 1 3 3 3 3 2 2 4 3 1 5 4 3 4 1 6 0 8 1 8 8 2 1 2 1 4 1 2 2 1 2 1 1 9 0 9 4 5 1 1 8 8 8 5 7 3 2 2 3 3 1 1 3 3 1 9 0 11 2 8 5 3 2 1 6 2 5 2 8 2 2 2 2 1 3 2 3 2 5 4 3 5 3 7 1 8 0 6 9 1 9 5 9 2 2 3 3 3 1 2 1 3 1 8 0 9 4 3 4 1 1 1 9 8 6 2 1 2 3 2 2 3 2 1 6 0 7 1 5 8 5 5 9 2 3 2 1 1 2 3 3 4 2 1 3 1 4 3 6 1 9 0 6 1 5 9 3 9 1 3 1 2 2 1 1 1 1 1 1 8 0 9 6 1 7 1 8 4 6 5 6 2 3 3 2 1 3 3 2 1 8 0 7 2 5 4 1 3 1 5 1 2 3 2 3 3 1 2 2 4 2 5 2 3 3 7 1 5 0 9 1 1 6 1 5 3 7 4 4 1 2 3 1 2 1 9 0 7 1 1 4 2 3 9 8 1 1 2 3 1 3 1 1 1 1 8 0 9 8 5 8 4 1 7 2 4 1 3 1 2 3 2 2 1 1 3 3 5 4 1 4 1 3 3 4 4 5 4 3 5 1 7 0 10 5 2 1 7 1 4 2 6 6 8 2 1 1 3 1 2 3 1 9 0 11 7 9 8 1 2 8 1 1 4 5 8 2 1 2 1 2 1 3 2 3 1 8 0 9 9 1 7 7 6 4 4 1 4 2 3 1 2 1 2 3 1 1 3 1 5 5 3 7 1 7 0 11 2 8 4 1 4 3 4 3 1 3 1 1 2 2 3 1 2 3 1 7 0 6 6 1 8 4 5 1 3 2 2 1 3 1 2 1 7 0 9 1 7 2 6 6 4 4 1 3 2 1 1 2 2 3 1 1 5 2 3 1 5 4 3 6 1 9 0 11 4 1 7 1 2 5 4 4 8 1 2 1 2 1 1 1 3 2 3 3 1 7 0 8 9 3 1 7 4 9 8 8 1 1 3 2 2 2 1 1 5 0 8 7 8 1 2 1 6 3 3 1 3 1 1 3 2 2 4 2 4 5 3 5 1 8 0 9 1 8 8 7 4 5 1 2 2 1 1 1 2 1 1 1 1 1 9 0 8 5 9 2 3 1 9 2 2 1 2 1 2 3 2 1 1 1 1 9 0 11 9 9 5 8 1 6 1 9 1 9 3 1 2 3 2 1 2 1 1 1 3 3 3 4 1 3 5 1 9 0 8 6 9 8 1 8 8 4 1 3 1 1 3 1 3 2 2 1 1 7 0 7 6 1 8 5 1 6 1 3 1 1 3 2 2 1 1 5 0 11 5 7 5 7 8 1 2 3 1 7 3 1 1 3 1 2 2 2 3 1 3 6 4 6 3 5 4 3 5 1 7 0 11 9 2 6 6 2 1 7 8 7 1 4 2 2 1 2 1 2 1 1 9 0 9 6 3 1 2 5 5 2 1 9 3 2 3 2 1 3 2 2 2 1 5 0 8 1 1 6 4 8 7 6 3 3 3 1 1 2 1 2 4 5 4 3 5 1 9 0 7 1 4 9 3 2 4 5 3 3 3 2 2 3 1 2 2 1 8 0 11 6 9 1 7 6 3 8 8 8 7 9 2 2 2 1 2 1 2 1 1 9 0 8 9 7 5 1 8 2 5 8 1 1 1 1 2 2 3 1 3 3 1 5 2 2 3 7 1 9 0 7 2 5 5 4 6 1 8 3 2 1 2 1 2 3 2 2 1 7 0 9 4 1 6 9 7 1 5 7 4 1 3 3 1 2 3 1 1 6 0 7 3 9 1 5 7 6 9 2 2 2 1 1 3 5 3 5 4 2 1 1 3 4 1 9 0 9 4 1 5 6 1 1 4 7 3 1 1 1 1 1 1 1 1 1 1 9 0 7 1 5 9 1 5 6 3 2 3 1 2 1 3 2 3 3 1 6 0 6 1 1 2 7 4 7 1 1 3 3 1 1 1 1 2 5 3 5 1 5 0 6 4 6 9 1 5 7 1 2 3 1 3 1 9 0 10 9 2 9 6 1 3 5 4 7 6 1 3 2 1 3 1 3 3 1 1 5 0 7 5 5 1 9 7 1 1 1 2 3 1 1 4 3 3 2 1 1 1 7 6 4 3 3 5 1 6 0 9 9 4 9 3 1 2 4 1 8 3 1 1 3 2 1 1 6 0 7 5 2 9 1 3 5 3 2 2 1 3 3 3 1 5 0 11 9 1 2 9 2 9 1 1 5 1 6 1 2 2 3 1 1 2 5 3 1 3 7 1 6 0 11 7 5 9 1 1 6 6 9 8 5 7 3 1 1 3 2 1 1 5 0 11 7 5 6 9 5 1 5 1 8 5 8 1 2 2 1 1 1 6 0 10 1 6 3 1 3 5 8 8 4 2 1 3 3 3 1 1 3 5 1 2 3 5 1 3 6 1 5 0 6 1 9 6 9 1 8 1 3 1 3 3 1 8 0 6 5 1 3 2 7 2 1 2 3 1 1 3 1 1 1 8 0 11 8 3 3 5 1 5 8 2 7 8 9 2 1 3 1 2 3 2 3 1 5 1 2 2 5 3 6 1 9 0 11 4 6 9 3 2 1 3 6 5 3 5 1 2 1 1 3 1 3 3 3 1 8 0 7 5 1 1 9 8 6 6 2 1 3 1 3 2 3 2 1 8 0 10 9 3 4 1 1 4 5 9 9 9 2 3 1 1 1 1 3 3 2 5 1 5 3 3 6 6 1 4 3 3 5 1 7 0 8 2 8 6 9 2 1 7 2 2 2 1 3 1 1 1 1 8 0 6 6 1 8 2 7 6 1 3 3 3 1 2 2 1 1 5 0 8 3 7 9 1 2 4 5 3 1 1 1 3 2 3 3 2 5 3 3 4 1 8 0 10 2 5 8 8 7 2 1 9 1 6 2 2 2 2 3 3 1 1 1 7 0 10 3 1 1 2 9 2 7 2 4 8 3 3 1 3 3 1 1 1 5 0 6 9 6 1 5 1 7 1 1 2 3 1 2 4 1 1 3 7 1 5 0 6 2 1 2 2 1 5 1 1 3 1 2 1 9 0 10 2 8 1 3 4 7 1 7 2 1 2 1 2 1 1 2 1 1 3 1 6 0 6 4 2 5 6 1 8 2 3 3 3 1 1 3 3 4 5 4 1 4 3 6 1 8 0 7 3 1 2 1 4 2 5 1 1 1 2 1 3 3 2 1 8 0 8 1 5 4 2 7 6 9 4 1 1 1 1 2 1 3 2 1 6 0 9 2 7 4 2 3 2 8 1 3 1 1 3 3 1 2 3 2 2 3 2 5 2 4 1 2 1 6 3 5 3 3 4 1 6 0 9 3 7 1 7 2 3 3 4 1 1 1 3 3 2 2 1 7 0 6 4 2 9 3 9 1 1 1 3 2 3 1 2 1 9 0 10 8 7 8 5 1 7 6 9 9 1 1 3 3 2 1 1 3 3 2 2 2 5 5 3 5 1 6 0 11 3 6 2 1 9 5 7 4 1 3 7 1 3 1 1 2 2 1 9 0 9 8 5 5 8 8 4 6 8 1 2 2 1 2 2 2 1 1 2 1 6 0 9 7 9 1 2 5 6 7 2 4 3 3 1 2 1 2 1 4 4 1 5 3 6 1 9 0 7 1 3 1 8 3 5 5 1 1 3 1 2 1 2 3 2 1 5 0 7 1 1 6 9 2 4 1 1 3 1 3 1 1 6 0 7 1 4 9 3 7 1 8 1 1 1 3 1 1 5 4 1 4 2 1 3 5 1 9 0 10 2 7 6 9 2 1 7 3 1 3 1 3 2 2 1 2 3 2 1 1 5 0 8 7 2 6 3 3 1 2 7 1 3 1 1 3 1 6 0 10 1 9 2 1 3 1 7 7 4 8 1 3 1 3 3 2 1 3 1 5 1 3 6 1 7 0 8 1 7 3 3 7 3 2 7 3 2 2 2 1 1 3 1 8 0 7 2 7 5 2 3 8 1 1 1 1 2 1 1 1 1 1 6 0 11 9 7 3 7 1 4 6 6 4 5 3 2 1 3 1 3 3 5 4 3 3 3 5 6 4 2 5 3 3 6 1 8 0 7 3 7 1 6 4 6 5 1 2 1 3 2 3 1 2 1 7 0 9 3 7 3 9 1 5 2 9 9 2 1 2 3 1 1 3 1 8 0 11 9 4 1 3 8 2 1 8 7 5 9 3 1 3 1 1 3 1 3 4 5 3 1 1 4 3 7 1 5 0 6 6 9 8 1 3 6 2 2 1 1 2 1 8 0 10 7 4 7 1 1 4 6 3 7 9 3 1 2 1 3 3 1 1 1 7 0 9 5 8 1 8 7 3 2 3 4 1 2 3 1 3 2 2 1 3 1 4 4 2 2 3 4 1 8 0 6 7 1 3 4 2 7 1 1 3 2 2 3 2 3 1 9 0 10 1 8 4 3 2 1 5 4 7 8 1 1 2 2 1 2 1 2 1 1 5 0 8 1 1 6 4 5 1 4 9 2 1 2 3 1 3 2 2 2 3 7 1 7 0 7 3 1 8 6 3 9 1 2 1 2 1 1 3 2 1 7 0 10 5 3 3 9 9 9 5 4 1 5 3 3 2 2 1 1 3 1 5 0 10 4 9 6 4 7 1 1 1 5 3 2 1 3 2 3 2 2 1 5 3 4 3 3 4 1 8 0 6 1 3 4 6 6 2 2 2 3 3 2 1 3 3 1 6 0 11 3 5 1 7 3 7 7 5 1 3 1 3 1 2 3 2 3 1 8 0 9 1 2 3 7 8 2 1 2 9 3 3 2 1 2 2 3 3 2 2 1 4 1 5 2 5 4 3 4 1 7 0 11 5 4 3 8 6 7 9 1 8 7 9 3 1 1 3 3 1 1 1 5 0 11 2 7 5 3 6 1 6 4 1 5 1 1 2 3 1 2 1 5 0 10 9 1 1 2 1 3 5 2 6 4 1 1 1 3 3 4 3 4 2 3 6 1 9 0 11 1 6 2 9 6 8 5 1 9 7 1 3 3 1 3 2 3 1 3 2 1 7 0 7 8 1 2 1 3 7 8 2 3 1 1 1 1 3 1 7 0 8 1 9 1 6 4 3 1 7 2 1 1 3 3 1 3 5 2 1 5 1 2 3 5 1 9 0 7 9 1 6 5 7 8 5 3 3 2 2 2 2 1 3 1 1 7 0 7 6 1 1 3 4 8 8 2 1 3 2 1 1 1 1 7 0 8 6 2 9 1 2 2 4 6 1 1 1 3 1 2 3 5 2 1 1 3 3 4 1 5 0 9 1 8 4 1 5 2 2 4 2 1 1 3 2 2 1 7 0 8 2 8 6 3 9 8 1 5 1 1 3 1 3 3 3 1 8 0 10 9 3 6 5 4 9 5 6 1 4 3 2 2 1 3 1 1 3 3 3 4 5 3 5 1 6 0 7 3 9 5 5 4 1 2 1 1 1 1 2 1 1 6 0 10 3 7 9 9 6 1 3 1 8 2 1 2 3 3 1 3 1 6 0 6 1 4 2 2 1 8 3 2 2 1 2 1 1 4 5 4 1 5 6 2 3 5 4 3 5 1 8 0 9 1 6 1 8 7 9 1 4 2 3 2 1 2 2 1 1 1 1 7 0 9 7 7 1 1 2 9 5 7 1 1 1 2 1 2 2 3 1 7 0 9 5 3 6 9 8 5 1 1 6 3 2 1 1 1 2 1 4 2 3 3 2 3 4 1 7 0 10 3 1 1 5 9 8 3 6 3 1 1 1 3 1 2 2 3 1 8 0 11 9 1 3 7 7 2 9 3 9 5 1 3 3 1 3 1 1 3 3 1 5 0 10 2 9 4 1 5 8 2 8 9 9 3 2 1 2 1 2 2 5 3 3 5 1 9 0 9 9 1 6 7 9 6 8 6 6 3 1 3 1 1 2 1 1 1 1 8 0 6 1 6 5 6 7 9 3 1 1 2 2 1 1 3 1 7 0 8 2 9 4 1 4 8 4 1 3 1 3 1 3 1 2 4 1 2 4 1 3 5 1 7 0 9 6 5 8 3 3 5 1 1 8 1 3 1 1 1 3 3 1 5 0 11 7 3 3 1 9 7 3 6 7 4 7 2 1 1 1 3 1 7 0 8 1 1 9 2 6 6 9 1 2 3 1 2 2 2 1 1 5 3 4 4 3 7 1 9 0 9 6 9 1 1 2 5 5 7 7 3 2 1 1 1 3 1 1 1 1 5 0 6 1 5 9 3 9 1 2 3 3 1 1 1 6 0 10 6 3 4 3 8 1 1 7 5 7 1 3 1 2 3 1 3 1 4 2 3 3 1 5 2 6 6 5 4 3 5 1 7 0 11 6 9 1 3 2 9 4 9 8 6 6 2 2 2 1 1 3 1 1 5 0 6 1 9 4 5 6 4 2 2 3 1 1 1 5 0 9 4 5 1 7 5 2 3 2 9 2 2 1 2 1 4 1 5 5 3 3 5 1 7 0 10 3 5 1 6 7 1 1 1 5 7 2 2 1 1 2 2 2 1 9 0 9 9 6 2 6 1 9 1 5 8 2 1 1 1 1 1 1 2 3 1 8 0 7 4 1 2 9 5 1 1 2 2 2 1 3 1 3 2 3 5 1 1 5 3 5 1 5 0 8 8 2 3 7 2 1 2 5 1 1 1 1 1 1 6 0 8 4 7 1 5 7 3 6 2 2 1 1 3 2 1 1 9 0 8 8 8 3 9 6 2 1 5 2 2 1 1 1 3 1 3 2 3 5 3 4 1 3 5 1 7 0 9 9 8 4 7 1 7 2 1 2 1 2 1 3 3 3 1 1 7 0 9 3 5 8 7 9 4 7 8 1 1 1 2 2 2 3 3 1 9 0 6 3 1 8 1 6 4 2 1 3 3 1 1 3 2 3 4 2 5 2 4 3 6 1 8 0 11 4 4 8 8 1 7 3 5 4 3 1 3 3 1 1 1 1 2 1 1 9 0 7 3 1 8 2 4 4 3 2 2 1 2 3 1 1 1 1 1 7 0 8 1 7 7 1 5 3 3 3 2 2 1 3 1 1 2 2 1 1 5 3 1 7 6 1 3 5 5 3 7 1 6 0 7 7 4 6 6 4 1 8 2 2 2 2 1 3 1 5 0 6 1 6 8 7 1 1 1 2 1 2 3 1 8 0 10 9 6 6 1 2 1 3 4 7 8 3 2 3 1 1 1 3 2 4 5 4 4 4 3 4 3 4 1 8 0 7 1 5 9 8 8 9 9 2 1 1 1 3 3 2 3 1 8 0 7 8 7 8 4 6 1 1 2 3 3 1 1 3 1 2 1 8 0 9 7 1 1 3 2 7 9 8 6 2 1 1 2 3 3 3 3 1 4 1 4 3 6 1 9 0 10 8 3 7 1 2 6 1 7 4 9 1 1 3 1 2 2 2 3 2 1 6 0 7 8 3 6 9 1 2 6 2 1 3 1 2 2 1 9 0 10 3 4 2 8 1 1 6 2 6 8 2 1 1 1 3 3 3 3 3 2 1 4 5 5 1 3 4 1 7 0 8 3 9 4 8 4 1 2 4 1 2 1 2 3 1 1 1 9 0 6 2 5 5 1 6 3 3 3 1 3 2 3 1 1 2 1 6 0 7 1 5 9 4 2 6 6 2 1 2 1 2 3 1 2 3 3 3 6 1 5 0 9 3 1 1 6 3 6 6 4 1 2 1 1 1 1 1 5 0 8 4 9 2 5 5 1 6 1 3 1 3 3 2 1 6 0 7 9 5 1 6 1 7 1 3 1 1 3 1 1 3 2 1 4 4 5 2 3 5 2 3 1 6 6 6 3 5 4 3 5 1 7 0 10 1 8 7 6 2 5 9 2 8 6 3 1 1 1 2 1 3 1 7 0 9 6 4 7 1 4 5 5 5 3 1 2 1 3 3 2 2 1 9 0 10 8 5 4 3 4 8 1 5 6 3 1 3 1 1 1 3 1 3 1 1 1 1 2 2 3 6 1 9 0 7 3 1 5 9 1 1 6 1 1 2 3 1 2 3 1 1 1 7 0 9 1 3 2 8 4 9 1 3 8 2 1 1 2 3 2 3 1 8 0 8 4 1 2 1 1 9 7 2 1 2 3 1 1 1 1 3 1 1 3 3 1 1 3 6 1 9 0 8 5 7 7 1 9 1 7 7 1 2 3 3 3 1 2 1 1 1 5 0 10 7 5 5 2 1 6 6 1 7 2 2 2 2 1 3 1 8 0 6 1 4 2 6 8 3 2 3 1 1 1 3 1 3 2 2 2 4 3 2 3 6 1 7 0 9 1 9 1 7 4 9 3 8 7 2 3 3 2 1 1 3 1 7 0 7 3 4 6 2 1 4 8 1 1 3 1 1 3 2 1 5 0 9 3 1 9 9 6 1 5 2 1 1 1 1 3 3 3 3 5 1 4 2 3 5 1 5 0 7 9 2 1 4 9 3 1 1 1 1 2 3 1 6 0 11 6 8 1 6 9 4 4 5 7 2 1 1 1 1 1 1 3 1 5 0 9 8 2 6 4 2 4 1 1 9 3 3 3 1 1 4 3 2 1 3 1 4 2 4 5 5 3 4 1 5 0 10 6 8 9 8 4 5 6 3 1 1 2 1 3 2 1 1 7 0 10 9 3 1 3 8 1 5 4 3 3 1 3 3 2 2 1 2 1 8 0 10 3 2 8 6 9 2 6 1 1 7 2 1 1 1 2 2 3 3 3 3 3 2 3 7 1 5 0 10 1 4 5 3 2 1 3 8 3 6 1 1 3 2 1 1 5 0 8 2 7 3 4 1 6 6 8 1 1 2 3 1 1 5 0 10 1 9 4 5 8 1 7 5 5 9 3 1 3 2 2 5 4 1 3 3 5 1 3 4 1 6 0 6 9 9 1 6 2 1 2 3 1 3 1 2 1 9 0 6 8 5 3 6 9 1 3 2 2 2 2 2 3 1 1 1 5 0 9 6 6 3 3 9 7 1 4 3 1 3 1 3 1 1 5 1 1 3 5 1 9 0 11 7 9 5 9 7 9 8 6 5 1 8 1 1 1 3 3 1 2 1 2 1 6 0 9 3 1 6 5 3 6 1 4 2 1 2 1 1 1 1 1 5 0 7 2 7 2 2 6 1 7 2 1 1 1 3 2 2 5 2 1 3 7 1 5 0 7 8 5 5 1 7 3 2 3 1 3 3 1 1 5 0 9 3 8 1 6 5 3 3 7 1 2 1 2 1 1 1 6 0 6 6 1 3 2 1 4 1 2 1 3 1 3 1 1 4 1 1 1 5 2 5 6 2 4 5 4 3 7 1 9 0 6 8 1 4 4 6 6 3 3 1 2 1 2 3 3 1 1 9 0 8 9 2 8 7 8 4 1 5 1 2 2 2 3 2 1 3 2 1 9 0 11 2 1 1 7 4 7 4 6 2 5 4 2 2 2 1 1 2 1 2 1 4 2 2 4 2 3 3 3 4 1 9 0 10 7 6 3 1 3 4 9 2 8 5 1 1 3 1 3 2 2 2 1 1 9 0 9 8 4 1 7 9 1 5 4 8 3 3 1 2 2 2 1 1 2 1 5 0 10 5 6 2 1 5 1 7 4 1 8 1 1 2 1 2 3 3 5 3 3 5 1 7 0 11 9 1 2 1 2 7 8 6 6 1 9 1 1 1 3 1 1 2 1 6 0 9 2 9 8 6 4 1 5 5 6 1 2 1 1 3 3 1 8 0 6 9 3 5 1 1 1 3 1 1 1 1 3 2 3 1 2 2 4 2 3 5 1 6 0 8 6 4 4 2 4 9 1 5 2 1 1 1 1 3 1 7 0 11 9 7 1 3 3 8 7 4 1 5 2 2 1 1 1 3 1 3 1 8 0 10 9 9 8 6 6 1 1 1 1 8 1 3 3 1 1 3 3 2 5 1 4 2 3 3 4 1 8 0 7 8 7 2 1 2 8 2 2 3 1 3 1 3 2 3 1 5 0 8 1 7 1 6 6 2 3 4 2 1 2 2 1 1 6 0 9 8 1 2 1 8 4 9 7 9 1 3 1 2 3 3 5 3 1 5 2 5 5 3 5 4 3 4 1 5 0 6 8 2 6 7 1 9 1 3 2 2 1 1 6 0 7 6 8 1 6 4 9 6 1 1 1 2 2 2 1 9 0 10 8 2 5 6 6 1 7 8 6 6 1 2 3 2 2 1 3 2 1 5 2 1 1 3 6 1 7 0 6 9 1 3 3 9 9 1 1 2 1 3 3 3 1 6 0 9 6 4 2 1 7 9 3 1 1 1 2 2 2 1 1 1 8 0 7 7 8 9 2 9 1 1 1 1 1 3 2 3 3 1 4 3 1 3 3 2 3 6 1 9 0 11 2 1 5 7 8 7 1 5 2 7 6 1 1 3 3 2 1 1 1 2 1 9 0 9 5 2 2 8 7 9 1 8 5 1 3 2 1 1 1 3 2 2 1 9 0 11 1 1 8 2 5 8 6 3 2 4 5 1 1 1 1 1 1 2 1 3 1 2 3 2 4 4 3 7 1 9 0 7 1 8 9 5 1 1 9 3 2 2 1 2 1 1 1 1 1 5 0 9 4 5 2 4 6 1 6 8 5 1 3 3 3 1 1 8 0 8 3 5 7 1 3 4 7 3 2 1 3 3 1 1 1 1 1 2 5 3 4 2 4 3 6 1 7 0 10 9 3 3 4 9 1 4 1 7 3 3 1 3 1 2 1 2 1 7 0 9 9 1 4 4 1 4 4 6 2 1 1 2 2 2 3 3 1 7 0 10 6 5 5 8 2 7 1 3 2 1 3 1 1 2 2 2 3 1 2 3 1 5 4 2 3 4 2 5 5 3 5 1 6 0 8 6 1 1 8 5 9 2 2 2 2 1 1 1 3 1 5 0 7 2 8 8 1 6 4 8 3 1 1 2 2 1 6 0 6 1 8 7 7 8 6 1 2 1 1 2 1 5 3 1 3 4 3 6 1 6 0 6 8 7 1 8 2 5 1 1 3 2 1 3 1 7 0 8 6 7 4 9 1 3 4 6 2 3 1 1 1 3 2 1 7 0 7 4 9 1 3 5 8 8 1 3 3 2 2 1 1 2 3 3 5 5 4 3 6 1 7 0 8 5 2 4 9 1 5 2 5 3 1 1 3 3 1 1 1 9 0 6 2 5 6 9 1 4 3 2 2 3 1 3 2 1 1 1 6 0 6 6 8 4 3 6 1 3 2 3 1 2 3 1 3 1 1 1 5 3 4 1 9 0 7 3 1 6 3 2 1 7 1 1 1 1 3 3 1 2 1 1 5 0 11 4 9 2 4 6 2 1 4 1 8 4 2 3 1 1 1 1 5 0 8 5 6 1 4 3 8 9 7 1 3 3 2 1 4 5 3 2 3 6 1 7 0 6 9 7 6 8 3 1 3 2 1 3 2 1 1 1 5 0 7 1 5 9 1 3 4 7 1 2 3 2 1 1 7 0 6 4 3 1 7 2 5 1 2 3 2 1 1 2 5 4 3 3 3 2 6 1 6 4 2 5 4 3 5 1 8 0 7 1 1 1 4 2 1 4 1 2 1 2 1 2 2 1 1 5 0 8 4 1 7 2 5 6 3 1 1 1 1 1 3 1 5 0 11 3 9 5 8 2 3 8 1 7 7 4 2 1 1 1 2 4 3 1 3 5 3 4 1 8 0 6 4 1 1 5 1 1 3 2 3 1 2 2 2 1 1 9 0 7 2 8 6 4 5 9 1 1 2 2 2 1 2 2 3 1 1 5 0 8 1 6 2 6 7 2 2 6 2 1 1 1 3 5 4 1 1 3 4 1 7 0 11 8 3 3 1 6 6 2 7 8 1 3 1 2 1 2 1 1 1 1 7 0 7 4 2 1 6 3 2 2 1 3 1 1 2 3 1 1 7 0 11 1 2 2 4 9 6 7 3 2 8 4 2 1 1 3 2 1 1 3 3 2 2 3 5 1 8 0 6 7 6 5 1 3 4 3 2 2 3 2 3 3 1 1 8 0 8 5 9 3 3 4 5 1 1 2 3 1 2 3 3 3 1 1 7 0 6 8 8 4 2 1 1 3 3 1 1 2 1 3 2 4 3 5 3 3 7 1 6 0 10 8 2 1 5 9 3 6 6 7 2 2 2 1 2 2 1 1 6 0 8 1 8 6 9 3 6 3 7 1 2 3 2 1 3 1 7 0 11 5 7 5 9 1 1 4 2 6 7 5 3 2 2 1 1 3 1 3 4 3 2 4 5 2 2 2 5 4 5 2 2 7 2 5 4 3 5 1 8 0 7 3 1 8 2 3 4 6 1 2 3 3 3 1 1 2 1 7 0 11 8 3 1 6 9 7 8 3 2 1 1 2 1 3 1 1 2 1 1 7 0 11 3 5 1 3 7 7 9 1 7 7 2 2 3 1 3 2 1 1 4 5 3 1 4 3 5 1 6 0 11 6 9 7 7 3 2 3 4 9 1 4 2 2 1 1 1 2 1 9 0 11 3 8 3 4 1 8 8 1 1 2 4 1 1 3 2 3 2 2 1 3 1 6 0 6 6 1 7 6 8 3 2 1 1 2 3 2 2 4 1 3 2 3 4 1 7 0 9 6 3 7 6 1 3 9 8 9 1 1 3 1 2 2 1 1 5 0 11 1 2 1 3 9 1 4 6 8 1 9 2 2 2 1 1 1 6 0 6 1 6 5 1 1 5 3 3 1 3 1 1 1 3 3 1 3 4 1 7 0 10 6 7 6 3 4 5 6 9 1 8 1 2 1 3 1 3 2 1 7 0 10 3 4 1 1 8 7 8 2 8 1 2 2 2 1 1 1 3 1 5 0 11 1 4 8 4 1 5 8 7 4 1 6 1 3 3 1 2 4 4 2 1 3 5 1 6 0 10 5 1 8 9 5 7 1 1 9 2 2 3 2 1 2 1 1 6 0 7 1 9 6 3 3 8 6 1 3 2 1 3 3 1 7 0 10 5 2 9 8 9 8 2 1 4 4 3 3 1 3 3 3 3 5 2 3 4 3 1 5 3 4 4 3 3 4 1 6 0 11 2 2 2 5 1 1 2 7 7 3 3 2 1 1 3 3 2 1 6 0 11 2 1 9 7 2 8 5 3 1 8 3 2 1 1 1 3 1 1 7 0 11 9 8 8 1 8 2 1 6 7 4 5 3 3 3 1 2 1 3 3 1 5 1 3 5 1 7 0 6 6 1 3 5 9 3 1 1 3 2 3 3 1 1 7 0 7 3 8 1 8 2 1 8 2 2 2 1 1 1 1 1 8 0 6 8 2 8 1 2 4 3 1 1 1 3 1 2 1 5 2 2 1 3 3 7 1 6 0 11 7 7 4 1 8 1 1 2 2 2 3 1 3 2 1 1 2 1 5 0 6 1 1 1 3 5 1 1 2 2 2 1 1 9 0 11 9 1 3 3 6 6 3 2 8 6 4 1 1 1 3 2 2 2 1 1 4 5 2 3 4 3 4 3 7 1 7 0 6 4 1 6 7 1 4 2 1 1 2 1 3 1 1 7 0 10 1 8 5 1 1 4 5 9 8 1 1 1 3 3 1 3 3 1 7 0 11 5 2 7 9 4 5 1 8 6 8 5 2 3 1 2 1 2 1 2 3 5 3 5 1 3 4 2 2 4 5 3 4 1 8 0 6 4 1 7 1 1 8 2 1 3 2 3 3 3 3 1 8 0 6 9 5 1 1 6 6 3 2 3 2 3 2 1 3 1 5 0 8 4 1 4 2 7 6 7 9 2 1 1 2 3 5 1 4 4 3 7 1 7 0 6 2 8 9 1 2 5 2 1 1 1 1 2 1 1 8 0 6 5 1 2 6 4 2 2 3 3 1 2 2 1 3 1 7 0 9 2 7 1 7 7 6 9 4 1 1 2 2 2 3 1 3 2 1 3 4 5 1 4 3 4 1 9 0 11 2 6 5 5 2 7 8 1 3 6 4 1 3 3 3 2 1 1 1 1 1 9 0 7 6 5 3 2 1 1 3 1 1 1 1 3 1 1 3 3 1 7 0 6 3 6 6 1 2 5 3 3 1 1 2 2 3 1 1 1 4 3 6 1 5 0 10 6 9 1 1 3 4 9 1 6 1 3 1 1 3 2 1 9 0 10 2 6 1 8 3 1 6 8 1 8 1 2 1 2 3 3 2 2 1 1 7 0 11 9 1 6 1 8 6 7 6 7 5 3 1 2 2 1 1 3 2 3 1 2 2 2 3 6 1 3 6 1 5 4 3 5 1 5 0 8 2 9 8 1 1 3 4 2 1 1 3 1 1 1 7 0 10 8 3 1 1 9 1 4 3 3 4 3 3 3 2 1 1 1 1 9 0 8 7 7 7 1 9 5 1 5 3 1 3 3 1 2 3 3 2 4 3 2 2 2 3 5 1 7 0 8 3 6 2 1 1 8 1 9 1 2 3 1 3 2 3 1 9 0 11 4 8 3 8 9 4 3 2 4 1 2 2 1 1 2 1 2 1 3 3 1 9 0 9 4 6 1 7 3 5 3 7 7 2 2 3 3 3 2 1 2 3 1 2 1 5 3 3 6 1 9 0 6 5 7 5 1 4 5 1 3 2 1 1 2 2 2 1 1 6 0 6 9 2 5 1 1 6 3 1 3 2 3 1 1 7 0 6 2 1 8 3 7 5 1 1 2 3 2 2 1 1 5 1 1 5 3 3 4 1 6 0 7 3 9 3 1 4 1 4 3 1 1 2 1 2 1 7 0 11 8 9 4 3 4 1 6 6 7 6 2 2 1 1 1 1 2 1 1 5 0 11 5 1 7 7 4 2 2 1 3 3 8 2 1 2 3 3 2 4 2 3 3 4 1 8 0 9 1 9 2 7 7 8 7 9 7 1 1 1 1 3 1 2 3 1 7 0 10 6 6 2 3 4 6 2 7 5 1 2 1 3 2 3 1 2 1 6 0 10 1 8 8 5 8 9 8 2 8 5 2 1 1 3 3 1 1 1 4 4 5 2 1 5 5 4 3 4 1 9 0 7 8 2 9 6 1 9 7 1 1 1 2 1 3 3 1 3 1 8 0 11 1 5 1 1 5 3 3 3 8 5 2 2 3 1 1 3 1 1 3 1 7 0 7 9 2 1 1 6 7 8 1 1 2 3 3 1 2 5 4 2 1 3 6 1 7 0 9 3 1 5 2 8 2 5 4 8 2 2 3 2 1 1 1 1 7 0 6 1 4 8 4 3 4 1 1 2 1 2 1 1 1 7 0 11 2 6 1 1 1 6 1 9 1 6 7 2 3 2 3 3 1 2 3 5 1 2 1 2 3 4 1 7 0 7 1 6 3 7 5 3 6 3 3 2 1 3 1 1 1 6 0 6 9 8 9 1 6 5 3 1 2 1 2 2 1 6 0 6 1 1 5 6 6 9 1 1 3 2 1 1 3 2 4 2 3 5 1 9 0 7 5 7 5 5 1 6 2 2 2 2 2 2 1 3 1 1 1 5 0 7 6 6 6 1 4 6 1 2 1 1 2 2 1 9 0 10 4 3 7 3 9 5 7 1 1 7 3 2 2 1 1 3 3 1 1 3 3 4 2 1 3 6 1 6 0 6 3 1 8 9 1 9 3 1 3 2 1 1 1 6 0 6 6 1 7 1 2 1 3 1 2 1 3 2 1 9 0 8 8 1 8 3 1 9 9 3 3 3 2 3 1 1 2 1 1 2 3 3 1 5 5 3 2 2 5 5 4 3 6 1 9 0 9 4 4 9 9 1 9 8 1 1 1 1 3 3 2 1 1 1 3 1 7 0 8 8 5 7 3 2 4 1 3 1 3 1 3 3 1 1 1 5 0 8 4 1 9 9 7 5 8 1 1 1 1 1 1 3 3 3 3 1 4 3 7 1 6 0 6 6 7 1 5 6 2 2 1 1 1 3 1 1 8 0 10 6 5 3 7 8 1 2 8 5 9 3 3 1 1 1 1 1 3 1 7 0 10 2 6 5 9 4 3 5 2 1 9 3 1 3 2 1 1 1 3 2 3 4 3 4 4 3 5 1 6 0 6 3 1 5 1 6 5 2 3 2 1 3 2 1 7 0 6 5 1 1 8 1 7 3 3 3 2 1 1 1 1 8 0 10 7 9 2 3 9 4 1 4 2 7 3 3 1 1 1 1 2 3 1 2 5 1 3 3 7 1 5 0 10 1 9 1 7 7 7 7 9 7 9 2 1 1 1 1 1 8 0 10 4 5 1 9 1 6 4 8 4 3 1 3 2 1 2 2 1 1 1 9 0 8 9 1 7 3 6 4 3 7 3 1 1 1 1 3 2 1 1 2 1 1 1 1 1 1 3 6 1 9 0 8 5 3 3 5 1 4 8 2 3 3 2 1 3 3 2 1 1 1 9 0 10 1 7 6 4 4 1 3 1 4 7 1 1 3 1 3 1 1 2 3 1 6 0 11 1 7 8 8 7 7 9 4 5 3 4 1 1 1 1 2 1 5 3 1 1 1 1 3 2 5 7 5 3 3 5 1 5 0 7 1 4 7 8 4 4 4 3 1 2 3 1 1 8 0 11 5 9 9 1 4 6 3 8 1 6 8 1 2 2 2 1 3 1 3 1 6 0 7 1 2 8 7 4 4 2 3 3 1 1 1 1 3 1 4 3 4 3 5 1 9 0 6 1 5 3 7 5 9 1 2 1 3 3 1 3 2 1 1 9 0 11 1 4 2 2 9 3 1 9 9 1 1 2 1 1 2 3 2 1 1 2 1 5 0 10 3 1 1 7 9 1 1 2 6 1 1 1 1 1 2 3 4 1 3 3 3 7 1 9 0 10 6 5 1 2 5 8 4 4 2 5 2 2 2 1 2 1 2 2 1 1 5 0 9 4 7 1 9 1 6 3 5 3 3 3 1 1 3 1 9 0 9 9 7 4 1 1 5 4 3 1 1 3 3 2 3 3 1 3 2 1 1 3 4 4 5 2 3 5 1 8 0 7 9 7 7 6 1 8 3 1 1 3 3 2 1 2 1 1 8 0 7 1 2 5 6 8 6 8 1 1 2 1 3 1 3 3 1 5 0 10 7 7 1 3 7 2 5 7 9 7 3 2 2 1 1 1 1 5 3 5 3 5 1 6 0 6 3 2 5 9 1 6 1 3 1 1 3 1 1 9 0 10 1 1 3 7 9 2 6 3 5 8 3 1 1 3 1 3 3 2 3 1 6 0 9 2 5 1 7 9 2 2 1 1 3 3 1 3 1 1 3 3 1 1 2 5 6 5 9 5 3 2 7 1 6 9 4 9 8 7 2 diff --git a/08/input_sample.txt b/08/input_sample.txt new file mode 100644 index 0000000..eff6c97 --- /dev/null +++ b/08/input_sample.txt @@ -0,0 +1,2 @@ +2 3 0 3 10 11 12 1 1 0 1 99 2 1 1 2 + diff --git a/08/solve01.py b/08/solve01.py new file mode 100755 index 0000000..88c470b --- /dev/null +++ b/08/solve01.py @@ -0,0 +1,26 @@ +#!/usr/bin/env python + + +def read_input(): + with open('input.txt', 'r') as f: + data = f.read().splitlines() + return [ int(x) for x in data[0].split(" ")] + + +def get_node_meta(data, pos): + num_ch = data[pos] + num_m = data[pos+1] + len_ch = 0 # total length of children + meta = [] + + for ch in range(num_ch): + (ch_len, ch_meta) = get_node_meta(data, pos+2+len_ch) + len_ch += ch_len + meta = meta + ch_meta + + meta = meta + data[pos+2+len_ch:pos+2+len_ch+num_m] + return (len_ch+2+num_m, meta) + +tree = read_input() +(_, meta) = get_node_meta(tree, 0) +print(sum(meta)) diff --git a/08/solve02.py b/08/solve02.py new file mode 100755 index 0000000..27605d9 --- /dev/null +++ b/08/solve02.py @@ -0,0 +1,35 @@ +#!/usr/bin/env python + + +def read_input(): + with open('input.txt', 'r') as f: + data = f.read().splitlines() + return [ int(x) for x in data[0].split(" ")] + + +def get_node_meta(data, pos): + num_ch = data[pos] + num_m = data[pos+1] + len_ch = 0 # total length of children + values = [0] * num_ch + value = 0 + + for ch in range(num_ch): + (ch_len, ch_value) = get_node_meta(data, pos+2+len_ch) + len_ch += ch_len + values[ch] = ch_value + + meta = data[pos+2+len_ch:pos+2+len_ch+num_m] + + # do not have children + if num_ch == 0: + value = sum(meta) + else: + for m in meta: + if m <= num_ch: + value += values[m-1] + return (len_ch+2+num_m, value) + +tree = read_input() +(_, value) = get_node_meta(tree, 0) +print(value) diff --git a/09/solve01.py b/09/solve01.py new file mode 100755 index 0000000..0e70009 --- /dev/null +++ b/09/solve01.py @@ -0,0 +1,75 @@ +#!/usr/bin/env python3 + + +def play(players, count): + marbles = dict() + marble_current = None + score = [0] * players + + def add_marble(num): + nonlocal marbles + nonlocal marble_current + + item = { + 'number': num, + 'prev': None, + 'next': None + } + marbles[num] = item + if len(marbles) == 1: + item['prev'] = num + item['next'] = num + else: + j1 = marbles[marble_current]['next'] + j2 = marbles[j1]['next'] + item['prev'] = j1 + item['next'] = j2 + marbles[j1]['next'] = num + marbles[j2]['prev'] = num + + marble_current = num +# print('adding marble {} next to {} and {}'.format(num, item['prev'], item['next'])) + + def rule_23(round): + nonlocal players + nonlocal marbles + nonlocal score + nonlocal marble_current + + j1 = marble_current + for i in range(7): + j1 = marbles[j1]['prev'] + + marble_current = marbles[j1]['next'] + j1p = marbles[j1]['prev'] + j1n = marbles[j1]['next'] + + marbles[j1p]['next'] = j1n + marbles[j1n]['pred'] = j1p + + player = round % players + score[player] += j1 + score[player] += round + +# print('removed marble {} between {} and {}'.format(j1,j1p,j1n)) +# print('added {} and {} to player {}'.format(j1,round, player)) + + for r in range(count): + if (r % 23 == 0) and (r > 0): + rule_23(r) + else: + add_marble(r) + + print(max(score)) + +#play(10, 26) +#play(10, 1619) +#play(13, 8000) +#play(17, 1105) +#play(21, 6112) +#play(30, 5808) +play(486, 70834) + + + + diff --git a/09/solve02.py b/09/solve02.py new file mode 100755 index 0000000..4c55c8e --- /dev/null +++ b/09/solve02.py @@ -0,0 +1,66 @@ +#!/usr/bin/env python3 + + +def play(players, count): + marbles = dict() + marble_current = None + score = [0] * players + + def add_marble(num): + nonlocal marbles + nonlocal marble_current + + item = { + 'number': num, + 'prev': None, + 'next': None + } + marbles[num] = item + if len(marbles) == 1: + item['prev'] = num + item['next'] = num + else: + j1 = marbles[marble_current]['next'] + j2 = marbles[j1]['next'] + item['prev'] = j1 + item['next'] = j2 + marbles[j1]['next'] = num + marbles[j2]['prev'] = num + + marble_current = num +# print('adding marble {} next to {} and {}'.format(num, item['prev'], item['next'])) + + def rule_23(round): + nonlocal players + nonlocal marbles + nonlocal score + nonlocal marble_current + + j1 = marble_current + for i in range(7): + j1 = marbles[j1]['prev'] + + marble_current = marbles[j1]['next'] + j1p = marbles[j1]['prev'] + j1n = marbles[j1]['next'] + + marbles[j1p]['next'] = j1n + marbles[j1n]['pred'] = j1p + + player = round % players + score[player] += j1 + score[player] += round + +# print('removed marble {} between {} and {}'.format(j1,j1p,j1n)) +# print('added {} and {} to player {}'.format(j1,round, player)) + + for r in range(count): + if (r % 23 == 0) and (r > 0): + rule_23(r) + else: + add_marble(r) + + print(max(score)) + +play(486, 7083300) +