Day 25: Forming groups master
authorJustin Worthe <justin@worthe-it.co.za>
Tue, 25 Dec 2018 07:03:35 +0000 (09:03 +0200)
committerJustin Worthe <justin@worthe-it.co.za>
Tue, 25 Dec 2018 07:03:35 +0000 (09:03 +0200)
inputs/25.txt [new file with mode: 0644]
src/bin/day_25.rs

diff --git a/inputs/25.txt b/inputs/25.txt
new file mode 100644 (file)
index 0000000..d359c48
--- /dev/null
@@ -0,0 +1,1248 @@
+-6,2,-8,3
+7,8,-1,-8
+7,-2,-4,-2
+4,-4,2,7
+5,8,-1,6
+-1,6,-4,-5
+-2,-6,-6,-6
+1,4,7,0
+-1,-3,-8,2
+5,-6,-5,-2
+-5,7,4,-2
+-2,6,-1,6
+5,4,0,-7
+1,5,-8,-3
+-3,3,8,2
+4,0,0,6
+4,-8,-3,3
+0,0,-7,-5
+-2,0,5,-3
+2,1,7,-1
+1,6,2,2
+4,4,7,-6
+-1,0,-1,1
+2,4,4,6
+-4,3,-7,2
+-5,-2,8,-7
+6,-8,-1,3
+-8,-6,-7,-3
+4,1,-7,-1
+-7,-5,-4,4
+5,-2,8,-5
+-5,-1,4,-4
+3,-3,8,4
+3,8,-8,-7
+-3,7,7,0
+-7,-5,-3,5
+-4,-5,-3,-2
+6,-8,3,8
+-2,0,8,7
+-4,3,5,7
+-6,3,5,0
+5,2,-3,-3
+0,8,0,5
+-5,-8,-1,-8
+2,6,0,6
+5,-4,0,0
+3,-2,-8,-5
+8,-4,-7,-7
+-3,-7,-8,-2
+6,7,-2,3
+5,0,-6,0
+0,-6,0,2
+8,-4,6,-3
+-5,-4,4,-4
+2,0,3,-1
+3,-5,8,5
+6,-1,5,5
+-6,-5,-4,8
+7,-4,0,5
+5,3,1,6
+-7,2,-3,1
+-4,1,-6,-7
+-4,4,0,8
+-6,4,1,-8
+3,-6,-6,5
+2,-4,-3,2
+-2,2,-2,1
+2,-4,0,0
+3,1,4,8
+-1,3,-7,-5
+-3,-7,2,0
+-2,-2,-8,0
+1,6,0,7
+-6,-3,0,-1
+7,0,-2,-7
+5,-5,-3,0
+7,0,0,5
+-6,5,6,2
+0,8,3,-1
+0,-8,-7,-1
+3,6,7,-7
+-2,4,-8,-3
+3,-3,-6,-4
+-1,-5,0,2
+-7,2,4,0
+-2,7,4,-2
+2,4,-1,5
+-1,-6,-6,4
+4,-6,-7,-2
+-6,6,-4,-2
+5,-5,-2,-6
+4,5,4,0
+3,3,0,-5
+-5,4,3,-2
+-6,1,7,-6
+3,5,-8,5
+-2,8,-2,-2
+-5,6,-2,-7
+-3,-6,7,-4
+-8,-6,7,7
+-5,-7,4,-4
+-8,-8,-6,7
+-7,-1,-2,-1
+3,-1,4,0
+3,6,1,-8
+2,6,-4,0
+-6,4,4,6
+7,7,6,-5
+4,-3,-2,7
+-1,8,2,-2
+3,-1,-4,5
+-2,1,-6,-8
+-3,1,7,-1
+-7,-1,8,6
+4,2,6,-6
+8,-1,8,-8
+4,6,-1,4
+7,-1,6,5
+0,-6,2,3
+-2,-8,-8,-6
+0,6,-4,-8
+4,-8,-7,6
+-3,-3,2,2
+2,1,4,7
+-3,7,-1,-8
+1,1,-2,-5
+3,-6,-4,7
+-3,5,0,8
+3,3,1,0
+1,5,4,6
+7,0,-2,-5
+1,5,-3,7
+-1,-4,3,4
+-4,3,-2,0
+-1,-8,2,0
+-8,-8,3,-3
+-2,-6,5,2
+8,-1,-3,-6
+2,-8,3,-5
+-8,-8,3,4
+-3,-5,-7,0
+0,3,1,3
+-8,5,-6,4
+2,0,4,-2
+-5,1,-7,0
+-5,0,-2,1
+4,-7,0,3
+7,0,4,-1
+0,-3,5,4
+-8,-8,-2,3
+2,5,4,6
+7,0,-8,-7
+-1,8,3,-3
+1,-2,2,-4
+-1,-3,3,-2
+4,6,7,-1
+3,8,2,-3
+-1,-8,8,7
+-8,4,7,-2
+-8,2,-8,-7
+-2,5,0,-5
+-1,-2,-5,-5
+4,6,-2,0
+0,8,0,-4
+2,0,-2,-1
+-8,0,-5,0
+-2,-8,-5,6
+2,0,5,7
+6,0,7,0
+-6,-8,3,-1
+2,2,6,-8
+-8,7,-8,7
+5,0,7,-6
+0,-3,6,-4
+-5,7,-6,-6
+2,5,0,-6
+-6,8,-3,3
+-8,-7,-1,-8
+-1,3,0,0
+1,2,3,-7
+-5,-1,7,2
+4,2,0,2
+-6,-6,-1,-2
+1,0,8,-1
+0,-1,-8,7
+2,2,-6,-4
+-2,3,2,6
+-6,-6,-2,-3
+-2,6,-2,1
+4,0,-8,7
+4,8,1,-1
+4,2,-2,5
+1,-2,-6,1
+1,5,-5,-4
+0,8,7,-6
+8,8,2,-3
+-3,-4,-5,3
+-2,6,-8,-1
+-2,-2,-4,2
+0,6,-3,7
+8,3,-3,7
+6,0,-1,-6
+8,8,3,0
+-7,0,8,7
+-5,7,-2,0
+2,-7,7,3
+8,-5,0,0
+-6,-8,1,-7
+-7,-3,0,5
+5,6,1,-7
+-3,8,-3,6
+-4,0,-4,-5
+7,4,2,1
+-7,-7,-8,6
+7,-7,4,4
+-6,-2,-1,1
+5,7,-6,-5
+1,6,-2,5
+-6,5,-6,3
+-6,-8,0,0
+2,-4,2,8
+0,0,0,-8
+-8,0,-2,2
+0,-4,-8,-8
+1,-5,-8,5
+6,-4,-5,6
+8,4,-5,-1
+8,-7,4,-4
+-7,-6,-8,0
+-2,3,-2,3
+-8,-3,-6,-3
+0,5,5,0
+3,7,-8,6
+0,-7,-5,-1
+1,6,-4,-3
+-4,5,-3,5
+7,-5,-5,8
+-4,4,0,-8
+7,-7,0,2
+6,0,2,-8
+-6,-4,1,0
+-1,0,-2,4
+-4,-8,5,7
+-8,4,-5,-2
+2,8,-8,-8
+-4,7,1,6
+-2,-2,-7,3
+6,4,-1,0
+-1,-7,-4,0
+-4,0,3,0
+0,3,5,2
+-4,-5,-1,0
+8,2,-6,0
+-2,5,-3,8
+7,0,3,-2
+6,0,-5,0
+4,-6,-5,6
+-7,8,0,-1
+8,-2,3,-4
+7,0,-4,7
+-4,-6,-7,-7
+2,8,0,4
+1,-6,5,-6
+4,-7,-2,-2
+4,1,-6,2
+0,7,4,3
+4,1,-1,-5
+1,-4,6,-6
+1,2,-2,-2
+2,-2,6,-5
+-8,6,-6,6
+0,6,8,2
+-3,-2,0,-8
+-6,-5,2,-6
+0,5,-8,-5
+1,-1,7,6
+-6,-3,-7,-3
+-4,-6,-1,0
+8,-3,-6,-2
+-5,-2,6,-1
+-1,0,3,1
+0,2,-6,7
+3,3,5,-2
+8,4,5,-1
+-5,-1,0,-1
+-6,-1,0,6
+2,6,-3,-3
+8,7,-8,4
+-6,-8,-3,0
+-1,-1,0,7
+6,-2,-8,4
+-3,8,3,-1
+6,2,0,4
+0,-3,7,3
+-5,3,-2,-1
+-6,-7,-2,-3
+4,-5,-3,-6
+-7,6,-2,4
+-2,-5,7,0
+1,8,-8,7
+8,3,-3,4
+-3,3,2,-4
+5,-7,4,1
+8,-3,-5,0
+-5,-4,-1,-8
+2,1,-2,-3
+-1,-4,-1,-7
+-7,-8,-7,-2
+3,0,7,4
+6,3,7,7
+0,-2,-4,2
+0,-1,-6,7
+-3,-8,-1,-7
+-8,-6,-6,-4
+-5,-4,-4,0
+0,7,-7,3
+-8,-7,-6,-8
+-5,3,0,-3
+-7,-6,0,7
+-7,6,-6,-2
+-2,8,2,-4
+2,0,0,5
+0,5,-2,0
+8,-7,-7,-1
+-1,3,2,-7
+-3,4,-7,-4
+-6,-3,2,-7
+-7,5,4,3
+5,-1,-6,-2
+3,-7,1,0
+-7,0,-4,-3
+-6,8,-1,0
+3,8,4,-2
+-1,-4,-8,-7
+3,3,8,1
+-5,1,4,5
+8,8,-1,2
+-3,-3,7,-4
+8,-3,2,-4
+6,-8,-6,8
+3,6,3,-2
+-7,-2,6,-4
+-6,-8,-8,5
+6,0,0,7
+-6,7,0,7
+8,0,-6,-3
+0,-3,-7,0
+-2,6,-7,-7
+5,-1,-3,0
+2,3,4,-5
+1,7,-6,0
+3,3,0,-3
+-1,0,-8,-8
+-2,5,-7,4
+7,-1,-8,5
+-2,-1,-1,6
+-2,-6,5,1
+4,-2,5,5
+-7,8,4,7
+-2,-2,6,5
+-6,1,-5,3
+-8,4,0,7
+8,-4,5,5
+-4,8,-4,1
+-8,0,5,4
+8,1,0,0
+-6,-8,-6,-2
+2,-5,0,0
+5,-6,5,-4
+1,2,7,2
+8,-4,6,5
+-6,0,7,6
+6,5,7,-6
+-2,-6,-2,5
+-6,-4,3,1
+6,-8,4,-4
+8,6,1,2
+7,5,7,-2
+7,-2,-6,-1
+4,-2,1,2
+1,1,-3,5
+0,-4,8,4
+5,2,-3,-4
+8,4,1,-3
+-1,1,-8,1
+-1,-1,0,5
+-4,4,6,0
+0,6,-2,6
+-3,4,5,5
+-7,5,4,-4
+2,2,-2,-4
+8,-1,2,-5
+-5,-2,6,-2
+7,2,1,6
+-3,-2,4,-5
+8,8,-7,-8
+0,1,-8,-4
+-3,-6,-3,3
+-4,-4,8,4
+-3,2,-4,-6
+-6,5,-5,-2
+-3,-7,-3,8
+0,6,-1,8
+8,0,7,1
+1,1,-8,-2
+6,-6,-7,3
+4,-5,8,-8
+-3,-6,6,7
+8,-5,2,4
+2,5,-3,-4
+-3,0,-6,7
+-1,-7,7,0
+2,-3,-5,5
+-7,-7,0,-2
+0,-4,7,8
+5,3,7,2
+-2,-7,5,5
+-6,-1,0,-8
+-3,0,8,-5
+-8,-1,1,1
+1,0,-6,8
+-1,-5,8,4
+-5,-4,4,8
+2,-3,0,-4
+-4,-3,0,7
+5,6,5,-5
+-3,-8,-3,-2
+5,8,-8,5
+-7,-2,-2,-2
+7,6,8,6
+0,-6,4,-7
+-1,-4,-7,0
+8,7,-6,6
+6,-5,-1,-3
+5,-2,-2,-3
+6,-3,-5,0
+-8,5,6,-5
+3,-7,7,8
+1,3,-8,0
+-6,8,-5,6
+6,-5,-5,-2
+3,8,1,-8
+-8,5,2,0
+0,5,-3,6
+-5,-7,-8,4
+0,7,0,0
+-5,6,-5,6
+-5,1,6,5
+6,1,-2,-8
+0,-8,3,1
+0,-3,-8,-3
+0,6,0,-2
+-8,0,-7,-5
+-8,2,0,6
+1,6,3,-4
+8,-5,0,-4
+-6,7,0,0
+5,0,1,0
+-8,8,2,8
+-7,4,2,4
+0,3,-2,-4
+-5,5,7,0
+5,0,-1,5
+-7,8,-6,8
+-8,-1,3,-3
+0,-7,-7,-7
+-4,4,8,-2
+1,2,1,-4
+1,-5,-1,8
+-3,8,-2,-2
+8,0,4,-4
+-8,5,-5,3
+-7,-7,-6,-2
+0,-6,-8,-8
+-1,-2,-3,0
+-4,0,1,7
+1,-6,-8,4
+0,8,6,-1
+-8,-5,-7,8
+2,7,-8,4
+-8,4,-3,2
+3,-1,-7,3
+4,-2,-6,-6
+-1,-4,1,-2
+3,-4,2,-6
+2,4,5,-3
+-7,7,1,6
+8,-6,-5,-3
+-7,1,-6,0
+-3,-6,-6,-8
+-8,-5,-6,4
+-5,-1,7,8
+0,7,6,2
+6,-2,-1,5
+0,4,-8,8
+-3,-5,-8,0
+2,-6,-2,-1
+5,8,-6,4
+-5,-1,0,-6
+-8,-5,8,2
+5,6,-3,-3
+-4,-7,2,6
+0,-3,-6,7
+-4,-6,-8,-8
+6,7,1,3
+7,-2,4,-3
+4,2,3,1
+0,8,-3,-8
+-8,0,1,0
+4,5,-4,-2
+-2,-6,4,2
+-4,0,-4,0
+8,-1,2,-2
+5,-7,8,1
+-2,5,-6,1
+6,-7,3,-7
+2,1,0,6
+-8,-3,-1,0
+8,-1,8,-3
+0,-6,6,0
+7,3,7,3
+-8,0,6,-1
+-5,-4,-5,0
+-2,0,3,-7
+0,2,0,0
+-3,6,6,3
+-6,-3,-1,-3
+8,0,1,5
+-7,4,-8,0
+8,8,-5,4
+-2,0,-7,-4
+-8,5,-7,-7
+8,0,-1,4
+8,-7,5,0
+-6,-1,-4,2
+-8,-8,6,-5
+7,2,-3,1
+2,0,2,6
+8,-7,-8,3
+-2,-7,-8,0
+0,3,-1,4
+-8,7,5,3
+0,-4,0,3
+6,6,-2,-6
+-4,8,6,-3
+0,3,0,-4
+6,-2,1,5
+1,4,4,3
+0,-7,4,-1
+1,3,-8,-2
+-5,0,4,0
+8,2,-6,-4
+-8,8,-2,6
+-5,7,-7,-2
+5,0,-4,-4
+-1,-5,3,7
+-2,-3,7,3
+-3,4,2,0
+-7,-8,1,3
+-8,-8,-3,2
+0,5,-8,7
+1,7,-6,5
+2,-6,-5,0
+-8,4,4,2
+7,3,1,-6
+-5,-4,8,2
+-7,7,0,0
+8,6,-1,6
+2,5,3,-7
+-7,3,1,5
+-8,-3,-4,3
+0,-2,0,8
+-7,-7,-5,8
+3,6,3,0
+-4,2,8,-4
+-6,2,6,-3
+0,-7,-6,-7
+0,-6,3,-6
+-4,-5,-5,-2
+1,-7,-2,-5
+5,7,0,4
+2,-1,3,-3
+7,1,-5,8
+0,3,0,2
+5,0,-5,-3
+-2,6,2,5
+6,4,-4,-7
+4,-8,4,8
+-5,-2,-6,7
+-1,-4,-4,5
+-2,-7,3,7
+-3,-8,-2,2
+1,-2,-5,-3
+0,-4,-1,3
+4,8,2,-5
+8,6,-6,1
+-8,-1,1,-4
+5,6,4,-8
+-7,-6,-5,4
+-3,-3,5,0
+-6,7,2,1
+-5,5,-1,0
+1,-8,2,0
+0,-3,-7,6
+4,-4,1,0
+-4,-6,0,4
+4,0,4,0
+4,-7,3,-2
+0,-3,0,4
+2,-3,2,2
+2,0,0,-4
+-8,6,6,4
+7,7,4,-2
+0,5,0,-1
+5,7,3,6
+5,2,4,-3
+5,4,-7,-6
+-8,1,7,2
+0,5,8,-1
+5,-3,-6,0
+-6,0,4,6
+-2,-2,6,-6
+-6,3,5,2
+8,-2,-3,-1
+-8,1,3,-4
+1,-6,-5,-6
+8,-4,6,-1
+-5,-7,-7,-5
+-1,-6,1,-4
+4,2,-3,0
+7,1,-4,4
+2,6,-8,0
+7,7,2,-5
+5,-2,-8,-3
+-5,0,3,2
+-1,6,-1,-4
+6,4,-3,-4
+4,1,4,-6
+3,5,0,-1
+5,-3,7,2
+3,-3,-7,5
+-3,-6,-1,2
+-7,-6,5,5
+-3,-7,1,-7
+5,5,-4,3
+6,-4,0,-1
+-7,-8,-1,7
+6,1,3,8
+8,-3,-5,2
+-3,1,-2,7
+-3,8,3,-4
+0,-8,7,3
+5,0,-4,-3
+3,-8,2,4
+-8,-3,6,-3
+0,6,-5,4
+-2,-8,-2,0
+-4,-4,-4,8
+-6,8,-5,-1
+-8,0,1,1
+-4,3,1,-2
+-1,-7,4,8
+3,0,7,-4
+5,7,3,-1
+7,-8,-3,1
+5,5,0,1
+-3,-1,0,8
+-6,-8,-4,1
+-3,-1,-6,0
+0,-1,0,0
+6,0,0,8
+3,-1,-4,6
+-4,4,0,-5
+3,7,1,7
+-5,0,6,7
+5,-5,2,3
+5,-7,2,1
+-6,1,-3,-6
+7,8,-2,8
+5,4,0,6
+-8,-3,4,-3
+-3,-6,2,6
+1,4,2,5
+0,7,6,-5
+-1,7,5,4
+4,-5,-4,0
+-2,1,4,-7
+-2,0,0,8
+7,0,1,1
+-3,-7,8,6
+-2,-8,6,7
+6,3,-4,5
+5,2,-5,8
+4,-2,5,-2
+8,5,-4,-4
+2,6,-7,6
+-4,-2,-6,-5
+0,5,-6,-1
+5,3,4,3
+4,2,1,5
+6,-6,-8,3
+-7,2,3,-2
+0,2,2,1
+0,1,2,3
+-6,4,1,-4
+7,-4,-1,4
+-5,3,-3,0
+3,8,-3,-4
+-2,-3,4,2
+4,7,-2,4
+4,-4,-3,-8
+1,0,-2,-6
+6,7,-4,0
+-2,-7,2,-2
+0,4,2,2
+-4,8,-1,0
+-4,5,1,1
+-2,-8,-1,4
+2,3,-3,4
+-8,-4,-5,0
+-6,3,0,2
+6,-5,1,0
+4,-2,-8,4
+0,7,-5,-2
+-7,-3,5,-1
+5,7,-4,1
+-3,-3,3,5
+2,0,-4,-4
+-7,0,6,6
+4,-4,-3,-1
+-6,6,-1,-6
+-1,2,1,-8
+-2,3,4,6
+5,8,-4,-8
+0,5,0,-4
+-5,-3,7,7
+5,4,5,-2
+4,-2,8,-5
+-4,2,-7,4
+1,-8,4,-4
+7,8,-7,3
+2,7,-8,-5
+-1,-5,6,-7
+5,-4,7,-2
+0,-3,0,6
+0,-7,-2,2
+4,8,0,-1
+0,-3,5,-3
+5,-6,0,4
+1,-7,2,-2
+-1,0,-3,1
+-4,0,4,-6
+5,3,7,3
+7,-4,7,-8
+-3,-5,3,7
+0,-6,8,2
+4,-6,-1,8
+0,-7,0,-8
+-4,5,0,6
+7,6,-6,2
+-6,-5,-7,3
+0,-1,4,-8
+4,6,-4,4
+-4,-2,5,4
+-8,-8,0,4
+2,-8,4,-1
+2,4,0,0
+-6,-1,8,7
+-6,5,8,-5
+-3,-5,-7,-3
+3,-1,-5,-7
+0,4,-4,-7
+2,-4,-1,-6
+-6,-6,0,5
+0,6,3,-5
+0,-3,8,2
+7,-6,6,-1
+-3,7,-4,-5
+-3,1,3,7
+5,-2,-6,-7
+-6,3,-1,8
+0,0,-4,-2
+-8,2,3,-4
+0,-2,-4,0
+1,8,-3,-7
+-2,-4,3,0
+3,-8,7,0
+-1,-6,3,-4
+3,0,8,4
+3,3,-5,-6
+5,0,-1,-2
+7,1,-4,8
+4,-5,3,-2
+4,-4,0,8
+-4,2,1,-8
+-8,0,-7,-2
+4,-2,0,0
+-8,3,7,-8
+8,-8,6,-5
+-8,0,3,-5
+6,3,-2,-3
+4,0,-5,7
+-1,-5,-6,2
+4,-1,-7,2
+-8,-1,-2,0
+1,7,-7,-2
+5,0,-5,-7
+8,-3,6,-2
+1,-6,2,-3
+6,-1,6,3
+-7,4,3,4
+-7,-5,-5,-4
+-7,2,-8,-4
+-5,8,3,-3
+1,2,-3,4
+-6,-5,-4,1
+5,4,5,7
+0,0,-1,-4
+5,-8,3,-1
+5,6,-5,0
+-7,-3,-6,0
+2,-8,0,1
+1,4,-7,-8
+-4,-7,-6,3
+0,1,-1,0
+-6,-1,6,0
+1,6,-4,-2
+8,-3,0,0
+-2,0,-3,7
+3,8,-4,3
+-8,7,2,0
+1,4,-6,3
+5,-3,4,-4
+-3,-5,5,5
+-6,4,-2,2
+-4,0,2,4
+-7,1,6,1
+-2,2,4,6
+-5,-2,6,0
+-1,4,8,0
+0,8,6,-6
+-6,6,-4,-7
+-6,-7,3,0
+4,-1,3,4
+0,-7,-4,-6
+-6,-5,-5,0
+-2,-5,-4,0
+2,0,-8,6
+-1,1,0,0
+-6,-4,-3,-1
+7,5,-7,1
+-5,-1,3,3
+6,1,0,1
+6,7,6,7
+-3,1,0,-3
+-5,-1,-6,4
+-5,1,1,8
+8,-1,-2,-6
+3,0,6,7
+0,8,4,0
+-8,0,-2,5
+-4,-3,-5,5
+-5,3,2,5
+-2,-3,0,-6
+-3,-4,1,-2
+8,-4,-7,-6
+2,8,6,-7
+3,-1,1,-6
+0,-8,1,3
+-2,-4,8,0
+7,-7,-3,5
+8,5,6,-5
+-3,7,2,8
+6,-1,-7,1
+-4,0,-2,-2
+7,8,1,-3
+-2,5,8,6
+-7,-5,0,3
+-7,3,-1,6
+2,-1,-4,0
+-8,-6,2,-8
+-7,-5,-5,1
+0,-5,-4,4
+5,-2,-3,-8
+-5,-8,1,4
+5,0,7,-4
+8,7,1,-1
+-4,-1,-5,2
+4,8,-6,1
+-3,2,3,4
+-5,-2,1,3
+-3,5,5,4
+-6,4,-1,5
+6,1,3,0
+0,-4,-5,0
+-4,4,2,6
+-7,-8,-6,7
+8,4,5,1
+0,5,-3,-1
+3,6,5,-8
+1,8,3,-6
+3,-3,-5,-8
+-7,5,-5,0
+-6,4,0,-6
+-7,7,6,-3
+-3,-1,7,8
+-7,-7,1,-4
+-7,-1,-8,6
+6,0,-2,2
+-5,-8,0,7
+-5,-4,8,4
+1,5,4,2
+8,8,-2,6
+-3,2,-2,1
+-5,-2,1,-2
+8,8,-8,-4
+-7,-8,8,-4
+0,-6,8,-2
+-6,8,1,0
+-8,0,8,-4
+-6,5,1,2
+1,7,5,-2
+-4,1,0,-7
+2,-8,3,7
+-1,-6,-2,-1
+3,-5,-1,7
+0,-7,2,1
+0,8,2,0
+-1,-2,-8,-2
+6,2,5,0
+7,-8,-8,0
+-2,1,2,6
+-3,-7,-4,2
+7,1,4,-3
+5,4,-1,1
+8,-8,8,-7
+3,7,7,-1
+0,-7,0,-4
+-4,2,7,-7
+-7,2,-5,7
+7,-3,2,0
+-8,1,2,0
+5,8,8,-3
+0,7,-2,7
+-3,0,0,-1
+6,8,3,-1
+1,0,-8,0
+8,-5,6,6
+3,0,0,3
+1,4,-4,4
+-2,-5,-3,3
+7,3,-1,-1
+2,-5,1,-5
+-3,-2,6,6
+0,7,-2,-2
+0,0,3,-7
+-1,-7,2,-2
+-6,-1,0,1
+-4,1,1,8
+-4,-6,1,1
+5,7,3,-3
+8,-2,4,2
+0,-6,5,-8
+4,5,0,-6
+1,0,-2,-1
+-6,0,0,-6
+-5,-7,-4,-6
+-8,8,-5,-2
+1,-7,0,4
+4,6,8,1
+-2,-6,6,6
+7,1,-6,0
+-5,6,-4,0
+-4,1,1,4
+8,-7,-1,4
+-7,8,4,-2
+8,5,-7,3
+2,-5,5,-1
+-5,-5,3,8
+-5,-3,-7,6
+5,2,2,1
+-1,-7,-5,2
+0,7,8,-5
+6,-4,5,0
+-1,5,-2,8
+-8,7,0,7
+-4,8,-1,1
+5,-1,1,-2
+2,-3,8,0
+0,6,-1,1
+-2,7,-7,8
+-6,1,-1,6
+5,7,-6,0
+-5,-1,-6,-6
+-2,3,-8,-5
+1,5,-7,-8
+7,-5,-2,5
+-5,7,5,-2
+-5,0,0,7
+-4,-4,0,0
+-3,0,2,-7
+5,4,3,-1
+-5,-7,7,5
+-2,-3,4,5
+-5,-3,4,2
+-7,0,-5,3
+0,0,-8,8
+0,5,-7,4
+-8,-3,8,-2
+-5,8,-2,-5
+-8,8,0,0
+-8,-3,5,-1
+-6,1,8,-3
+3,7,-6,3
+-6,6,2,5
+1,-4,-3,0
+-8,-8,5,3
+1,-4,8,-2
+4,7,3,1
+7,0,4,0
+0,3,-4,-2
+-7,3,7,4
+-4,-7,-1,3
+1,-7,2,1
+3,3,-5,-1
+5,-7,2,2
+1,-4,-4,0
+-8,5,-3,-1
+3,-3,4,0
+7,0,4,-5
+0,1,1,2
+1,-5,6,-5
+-3,2,7,7
+-3,-3,6,2
+2,-2,0,-3
+3,8,-3,2
+-1,1,3,-4
+2,7,4,8
+7,6,-1,6
+8,8,6,5
+2,8,-6,-7
+-1,-3,-3,3
+4,0,-5,-1
+-4,-4,-1,2
+2,-1,-2,-3
+3,3,-3,1
+-1,3,2,2
+4,1,4,7
+-1,-6,-4,2
+-5,-5,2,-1
+-2,2,0,-5
+-1,-8,5,-2
+-6,1,-1,-1
+-8,-8,0,2
+7,8,-7,-1
+-6,7,0,-6
+-4,4,8,-7
+7,1,5,7
+-5,2,2,-5
+1,-2,-3,0
+0,7,-8,-5
+-1,0,-5,6
+-6,1,-4,-3
+8,2,4,-7
+0,-3,0,-7
+6,-5,-8,-4
+-3,4,-3,7
+0,-1,-8,2
+3,1,-8,0
+-8,1,3,7
+-7,1,8,6
+7,7,-3,7
+4,0,2,-3
+0,-2,1,-7
+-7,6,-3,7
+-3,8,-7,4
+6,4,2,5
+3,-3,6,-7
+6,-8,-3,-1
+-2,-8,-8,4
+-3,-2,1,6
+3,1,-1,-1
+8,6,7,5
+5,7,7,-8
+-7,3,3,4
+8,6,-5,-4
+1,-4,-5,-3
+4,6,-6,-6
+-3,4,0,7
+1,-4,-3,8
+3,-7,-2,1
+2,-4,4,8
+-5,1,-7,5
+0,-5,0,3
+0,7,-8,5
+-8,-2,1,3
+-5,8,8,6
+0,5,4,-1
+0,-8,-7,8
+3,2,1,-7
+2,-3,4,1
+5,4,7,-3
+-8,-3,7,-3
+-2,5,6,-5
+5,0,0,-3
+-4,6,6,1
+8,-2,-5,2
+0,4,-2,3
+-8,-5,-8,6
+-5,0,5,7
+-7,1,-8,4
+7,2,6,-2
+-2,-7,-2,6
+-7,7,0,5
+-5,-3,1,4
+-4,8,2,3
+-7,0,0,-6
+2,4,0,8
+2,7,7,0
+7,4,-4,-3
+2,7,5,7
+-3,4,1,3
+-2,-3,-3,1
+2,8,-1,8
+0,-7,6,8
+1,6,5,5
+-8,-6,-6,-5
+6,-8,-8,-1
+-8,3,3,3
+5,-7,7,-2
+5,8,1,6
+0,2,3,5
+-2,7,-7,-3
+-5,6,1,-5
+6,7,-1,4
+8,-3,6,-7
+5,0,-8,3
+0,6,2,0
+-8,-6,-6,5
+0,7,2,-3
+1,-4,6,-7
+-6,7,0,4
+4,-4,0,4
+6,3,7,-2
+3,-8,2,3
+0,5,3,-8
+2,6,7,4
+2,-7,-5,1
+-8,-3,-2,4
+-7,-7,0,4
+-4,-5,-6,1
+-6,-6,0,-3
+-8,8,-3,-4
+-6,7,1,-6
+-5,4,0,7
+-4,-1,5,3
+5,-7,3,1
+0,-4,-6,-3
+6,-6,-1,-5
+3,1,5,-3
+-1,1,2,-3
+0,7,-1,-7
+-8,0,8,0
+0,8,0,-6
+2,-7,2,0
+0,-1,-2,-7
+-2,0,1,1
+1,-7,8,4
+3,-6,0,7
+0,0,-5,4
+2,-7,0,6
+-6,4,5,-7
+-3,5,7,4
+-2,-1,7,8
+-7,0,-2,-4
+3,-6,6,0
+5,-4,-4,4
+6,8,8,-3
+6,-6,-6,3
+2,-3,-3,-3
+8,-5,-2,0
+-3,5,7,-4
+-7,-8,1,5
+0,-1,-1,-1
+8,1,7,-8
+4,4,2,4
+6,2,-1,2
+-5,6,-6,5
+-2,-5,-3,4
+6,-3,-4,0
+8,8,-5,-7
+2,2,0,-3
+-5,-8,1,2
+7,-6,-2,8
+-5,0,-3,3
+-2,7,-4,-5
+8,-1,-6,1
+7,6,-1,-4
+-3,0,2,1
+0,0,5,0
+-1,8,-2,3
+-3,2,1,-8
+1,7,-7,0
+1,4,-1,0
+6,-4,3,-2
+-1,-6,-2,2
+-2,2,2,2
+2,0,-3,5
+-4,1,-8,-3
+-4,1,5,-7
+-6,8,1,4
+5,3,0,1
+-8,-7,7,-1
+-8,-3,1,-7
+0,2,4,7
+6,7,2,-8
+4,1,2,8
+3,-2,1,-5
+8,2,-7,6
+8,0,5,3
+-7,4,8,-7
+3,8,-1,-7
+-1,-5,-2,0
+-3,0,6,3
+6,5,-3,-2
+1,8,7,-2
+-4,-1,-7,-2
+-6,-1,8,3
+8,-1,5,-6
+5,0,5,2
+-4,8,0,-1
+-5,2,7,-3
+5,-2,-6,5
+4,-4,4,0
+-7,-1,-5,-5
+-8,-5,4,5
+4,-6,-8,3
+7,2,7,-5
+1,6,2,-3
+-3,3,-8,0
+1,-6,7,-3
+-5,8,6,-3
+-3,-2,-4,-6
+7,-7,-2,1
+5,4,-7,-1
+3,-4,-5,-1
+-1,-5,6,-1
+-8,4,-5,1
index 4301af4..9e74f49 100644 (file)
@@ -9,10 +9,39 @@ use std::path::PathBuf;
 fn main() -> Result<(), Box<Error>> {
     let input = read_file(&PathBuf::from("inputs/25.txt"))?;
 
-    println!("Input: {:?}", input);
-
+    let mut constellations: Vec<Vec<Vec<i32>>> = input.iter()
+        .map(|line| line.split(',').map(|x| x.parse().unwrap()).collect::<Vec<_>>())
+        .map(|points| vec!(points))
+        .collect();
 
+    // debug!(constellations);
 
+    while join_constellations(&mut constellations) {
+    }
 
+    debug!(constellations.len());
+    
     Ok(())
 }
+
+fn distance(xs: &[i32], ys: &[i32]) -> i32 {
+    xs.iter().zip(ys.iter()).map(|(x,y)| (x - y).abs()).sum()
+}
+
+fn join_constellations(constellations: &mut Vec<Vec<Vec<i32>>>) -> bool {
+    for i in 0..constellations.len()-1 {
+        for j in i+1..constellations.len() {
+            let connected = constellations[i].iter().any(|ci| {
+                constellations[j].iter().any(|cj| {
+                    distance(&ci, &cj) <= 3
+                })
+            });
+            if connected {
+                let mut to_join = constellations.remove(j);
+                constellations[i].append(&mut to_join);
+                return true;
+            }
+        }
+    }
+    false
+}