Add solution for day 5
parent
f956229696
commit
d1498c581e
|
@ -0,0 +1,513 @@
|
|||
[H] [S] [D]
|
||||
[S] [C] [C] [Q] [L]
|
||||
[C] [R] [Z] [R] [H] [Z]
|
||||
[G] [N] [H] [S] [B] [R] [F]
|
||||
[D] [T] [Q] [F] [Q] [Z] [Z] [N]
|
||||
[Z] [W] [F] [N] [F] [W] [J] [V] [G]
|
||||
[T] [R] [B] [C] [L] [P] [F] [L] [H]
|
||||
[H] [Q] [P] [L] [G] [V] [Z] [D] [B]
|
||||
1 2 3 4 5 6 7 8 9
|
||||
|
||||
move 2 from 7 to 2
|
||||
move 1 from 4 to 8
|
||||
move 2 from 1 to 9
|
||||
move 4 from 6 to 5
|
||||
move 1 from 7 to 6
|
||||
move 2 from 1 to 4
|
||||
move 7 from 8 to 9
|
||||
move 7 from 4 to 5
|
||||
move 4 from 2 to 4
|
||||
move 1 from 5 to 9
|
||||
move 14 from 5 to 4
|
||||
move 1 from 3 to 8
|
||||
move 5 from 4 to 8
|
||||
move 1 from 2 to 5
|
||||
move 2 from 4 to 1
|
||||
move 6 from 8 to 1
|
||||
move 1 from 8 to 6
|
||||
move 1 from 2 to 5
|
||||
move 5 from 3 to 7
|
||||
move 2 from 6 to 3
|
||||
move 2 from 4 to 7
|
||||
move 3 from 3 to 9
|
||||
move 7 from 4 to 1
|
||||
move 1 from 6 to 9
|
||||
move 2 from 6 to 1
|
||||
move 3 from 5 to 2
|
||||
move 1 from 1 to 8
|
||||
move 21 from 9 to 1
|
||||
move 1 from 4 to 2
|
||||
move 7 from 7 to 2
|
||||
move 1 from 4 to 2
|
||||
move 23 from 1 to 5
|
||||
move 5 from 5 to 1
|
||||
move 1 from 3 to 6
|
||||
move 1 from 6 to 3
|
||||
move 12 from 1 to 6
|
||||
move 1 from 3 to 6
|
||||
move 2 from 1 to 8
|
||||
move 1 from 9 to 3
|
||||
move 2 from 8 to 1
|
||||
move 2 from 1 to 8
|
||||
move 1 from 1 to 3
|
||||
move 2 from 3 to 1
|
||||
move 2 from 8 to 1
|
||||
move 3 from 6 to 1
|
||||
move 1 from 8 to 7
|
||||
move 4 from 6 to 2
|
||||
move 3 from 6 to 9
|
||||
move 2 from 5 to 7
|
||||
move 2 from 7 to 8
|
||||
move 1 from 7 to 9
|
||||
move 9 from 1 to 5
|
||||
move 12 from 5 to 9
|
||||
move 1 from 8 to 6
|
||||
move 1 from 6 to 9
|
||||
move 1 from 6 to 9
|
||||
move 7 from 9 to 4
|
||||
move 10 from 2 to 1
|
||||
move 12 from 5 to 4
|
||||
move 7 from 4 to 9
|
||||
move 7 from 4 to 7
|
||||
move 1 from 5 to 4
|
||||
move 7 from 7 to 8
|
||||
move 1 from 6 to 3
|
||||
move 1 from 3 to 1
|
||||
move 3 from 2 to 4
|
||||
move 1 from 6 to 8
|
||||
move 7 from 1 to 2
|
||||
move 1 from 6 to 7
|
||||
move 12 from 9 to 4
|
||||
move 3 from 8 to 5
|
||||
move 1 from 7 to 3
|
||||
move 6 from 9 to 1
|
||||
move 10 from 1 to 9
|
||||
move 7 from 9 to 5
|
||||
move 3 from 9 to 5
|
||||
move 1 from 3 to 4
|
||||
move 2 from 2 to 1
|
||||
move 1 from 5 to 1
|
||||
move 9 from 4 to 3
|
||||
move 1 from 1 to 3
|
||||
move 8 from 4 to 7
|
||||
move 7 from 5 to 3
|
||||
move 2 from 7 to 2
|
||||
move 8 from 3 to 9
|
||||
move 1 from 1 to 8
|
||||
move 10 from 2 to 3
|
||||
move 4 from 8 to 7
|
||||
move 12 from 3 to 4
|
||||
move 9 from 7 to 2
|
||||
move 2 from 1 to 3
|
||||
move 1 from 9 to 6
|
||||
move 2 from 4 to 9
|
||||
move 1 from 7 to 6
|
||||
move 5 from 5 to 9
|
||||
move 8 from 3 to 1
|
||||
move 2 from 6 to 3
|
||||
move 14 from 4 to 3
|
||||
move 15 from 3 to 9
|
||||
move 1 from 3 to 1
|
||||
move 3 from 9 to 8
|
||||
move 1 from 8 to 1
|
||||
move 1 from 3 to 2
|
||||
move 5 from 2 to 8
|
||||
move 1 from 4 to 2
|
||||
move 2 from 1 to 3
|
||||
move 2 from 3 to 9
|
||||
move 3 from 2 to 4
|
||||
move 6 from 1 to 8
|
||||
move 2 from 2 to 6
|
||||
move 1 from 6 to 4
|
||||
move 2 from 4 to 7
|
||||
move 5 from 8 to 5
|
||||
move 1 from 6 to 9
|
||||
move 7 from 9 to 6
|
||||
move 1 from 5 to 3
|
||||
move 2 from 7 to 8
|
||||
move 2 from 2 to 4
|
||||
move 3 from 5 to 6
|
||||
move 1 from 3 to 8
|
||||
move 1 from 5 to 6
|
||||
move 2 from 4 to 1
|
||||
move 3 from 1 to 6
|
||||
move 21 from 9 to 5
|
||||
move 1 from 4 to 3
|
||||
move 1 from 4 to 9
|
||||
move 2 from 9 to 2
|
||||
move 1 from 3 to 9
|
||||
move 4 from 2 to 3
|
||||
move 3 from 8 to 1
|
||||
move 14 from 5 to 9
|
||||
move 7 from 5 to 4
|
||||
move 3 from 8 to 4
|
||||
move 4 from 3 to 2
|
||||
move 3 from 8 to 5
|
||||
move 1 from 2 to 3
|
||||
move 1 from 5 to 1
|
||||
move 2 from 5 to 4
|
||||
move 3 from 2 to 9
|
||||
move 11 from 4 to 1
|
||||
move 17 from 9 to 2
|
||||
move 17 from 2 to 9
|
||||
move 10 from 9 to 2
|
||||
move 2 from 8 to 2
|
||||
move 3 from 8 to 3
|
||||
move 8 from 9 to 7
|
||||
move 4 from 7 to 3
|
||||
move 2 from 3 to 2
|
||||
move 3 from 2 to 3
|
||||
move 9 from 3 to 5
|
||||
move 1 from 1 to 9
|
||||
move 8 from 5 to 1
|
||||
move 2 from 7 to 9
|
||||
move 24 from 1 to 3
|
||||
move 24 from 3 to 6
|
||||
move 1 from 5 to 3
|
||||
move 10 from 2 to 1
|
||||
move 1 from 4 to 5
|
||||
move 3 from 9 to 1
|
||||
move 1 from 3 to 5
|
||||
move 17 from 6 to 5
|
||||
move 1 from 7 to 4
|
||||
move 13 from 5 to 4
|
||||
move 3 from 5 to 8
|
||||
move 1 from 7 to 9
|
||||
move 3 from 6 to 9
|
||||
move 8 from 6 to 4
|
||||
move 1 from 9 to 6
|
||||
move 11 from 1 to 8
|
||||
move 1 from 5 to 6
|
||||
move 12 from 4 to 9
|
||||
move 2 from 5 to 1
|
||||
move 1 from 1 to 7
|
||||
move 5 from 9 to 2
|
||||
move 1 from 7 to 9
|
||||
move 3 from 1 to 5
|
||||
move 3 from 5 to 9
|
||||
move 7 from 9 to 3
|
||||
move 4 from 9 to 6
|
||||
move 3 from 6 to 8
|
||||
move 5 from 4 to 3
|
||||
move 2 from 2 to 6
|
||||
move 3 from 9 to 3
|
||||
move 3 from 6 to 4
|
||||
move 4 from 2 to 6
|
||||
move 11 from 3 to 5
|
||||
move 11 from 6 to 9
|
||||
move 2 from 3 to 5
|
||||
move 1 from 5 to 8
|
||||
move 3 from 6 to 2
|
||||
move 7 from 9 to 2
|
||||
move 8 from 5 to 7
|
||||
move 6 from 4 to 5
|
||||
move 2 from 4 to 3
|
||||
move 1 from 8 to 6
|
||||
move 4 from 8 to 3
|
||||
move 13 from 8 to 3
|
||||
move 1 from 9 to 5
|
||||
move 6 from 7 to 2
|
||||
move 1 from 7 to 6
|
||||
move 1 from 6 to 5
|
||||
move 2 from 6 to 7
|
||||
move 13 from 3 to 5
|
||||
move 6 from 2 to 7
|
||||
move 1 from 6 to 1
|
||||
move 1 from 2 to 8
|
||||
move 2 from 7 to 8
|
||||
move 14 from 5 to 8
|
||||
move 1 from 1 to 4
|
||||
move 9 from 2 to 1
|
||||
move 14 from 8 to 7
|
||||
move 3 from 3 to 9
|
||||
move 11 from 5 to 3
|
||||
move 1 from 4 to 5
|
||||
move 4 from 9 to 8
|
||||
move 4 from 8 to 7
|
||||
move 5 from 3 to 9
|
||||
move 11 from 7 to 8
|
||||
move 9 from 1 to 3
|
||||
move 4 from 3 to 2
|
||||
move 6 from 8 to 4
|
||||
move 2 from 8 to 2
|
||||
move 13 from 3 to 6
|
||||
move 1 from 4 to 1
|
||||
move 5 from 4 to 2
|
||||
move 10 from 2 to 6
|
||||
move 4 from 9 to 1
|
||||
move 8 from 7 to 8
|
||||
move 10 from 8 to 5
|
||||
move 2 from 3 to 2
|
||||
move 2 from 8 to 6
|
||||
move 1 from 7 to 1
|
||||
move 2 from 7 to 6
|
||||
move 2 from 2 to 9
|
||||
move 2 from 8 to 6
|
||||
move 6 from 1 to 7
|
||||
move 5 from 9 to 1
|
||||
move 4 from 7 to 8
|
||||
move 1 from 7 to 2
|
||||
move 2 from 1 to 7
|
||||
move 1 from 3 to 8
|
||||
move 1 from 1 to 6
|
||||
move 2 from 2 to 6
|
||||
move 1 from 7 to 8
|
||||
move 1 from 1 to 9
|
||||
move 8 from 5 to 7
|
||||
move 2 from 7 to 9
|
||||
move 9 from 6 to 3
|
||||
move 13 from 6 to 8
|
||||
move 3 from 9 to 1
|
||||
move 5 from 6 to 1
|
||||
move 3 from 8 to 1
|
||||
move 3 from 3 to 4
|
||||
move 1 from 4 to 3
|
||||
move 1 from 4 to 8
|
||||
move 4 from 6 to 3
|
||||
move 11 from 8 to 2
|
||||
move 1 from 6 to 9
|
||||
move 8 from 3 to 9
|
||||
move 3 from 5 to 8
|
||||
move 4 from 1 to 2
|
||||
move 6 from 8 to 5
|
||||
move 6 from 5 to 1
|
||||
move 5 from 1 to 3
|
||||
move 3 from 3 to 4
|
||||
move 3 from 8 to 4
|
||||
move 2 from 4 to 5
|
||||
move 10 from 7 to 8
|
||||
move 5 from 9 to 2
|
||||
move 1 from 7 to 5
|
||||
move 3 from 5 to 2
|
||||
move 4 from 9 to 3
|
||||
move 4 from 1 to 5
|
||||
move 1 from 3 to 2
|
||||
move 3 from 5 to 2
|
||||
move 6 from 2 to 5
|
||||
move 10 from 8 to 3
|
||||
move 4 from 4 to 5
|
||||
move 4 from 2 to 8
|
||||
move 12 from 3 to 8
|
||||
move 1 from 1 to 3
|
||||
move 9 from 8 to 6
|
||||
move 1 from 4 to 1
|
||||
move 6 from 8 to 7
|
||||
move 3 from 1 to 7
|
||||
move 9 from 5 to 7
|
||||
move 11 from 7 to 2
|
||||
move 2 from 7 to 3
|
||||
move 9 from 2 to 7
|
||||
move 1 from 8 to 7
|
||||
move 1 from 5 to 2
|
||||
move 2 from 6 to 2
|
||||
move 2 from 1 to 2
|
||||
move 6 from 3 to 5
|
||||
move 2 from 3 to 6
|
||||
move 4 from 7 to 3
|
||||
move 3 from 3 to 1
|
||||
move 2 from 1 to 5
|
||||
move 7 from 7 to 6
|
||||
move 1 from 1 to 5
|
||||
move 3 from 2 to 4
|
||||
move 1 from 3 to 2
|
||||
move 18 from 2 to 1
|
||||
move 4 from 2 to 7
|
||||
move 6 from 5 to 9
|
||||
move 1 from 4 to 8
|
||||
move 2 from 6 to 1
|
||||
move 19 from 1 to 2
|
||||
move 4 from 9 to 5
|
||||
move 5 from 7 to 2
|
||||
move 1 from 8 to 7
|
||||
move 1 from 1 to 2
|
||||
move 6 from 5 to 7
|
||||
move 1 from 3 to 8
|
||||
move 6 from 7 to 6
|
||||
move 1 from 4 to 1
|
||||
move 4 from 7 to 9
|
||||
move 1 from 1 to 3
|
||||
move 1 from 2 to 5
|
||||
move 1 from 4 to 8
|
||||
move 1 from 3 to 4
|
||||
move 3 from 5 to 4
|
||||
move 2 from 8 to 9
|
||||
move 9 from 2 to 4
|
||||
move 19 from 6 to 4
|
||||
move 1 from 4 to 7
|
||||
move 5 from 9 to 5
|
||||
move 10 from 2 to 9
|
||||
move 2 from 5 to 4
|
||||
move 14 from 4 to 7
|
||||
move 2 from 2 to 1
|
||||
move 3 from 9 to 1
|
||||
move 1 from 1 to 3
|
||||
move 13 from 7 to 6
|
||||
move 1 from 5 to 9
|
||||
move 1 from 6 to 9
|
||||
move 1 from 7 to 2
|
||||
move 5 from 9 to 7
|
||||
move 1 from 5 to 2
|
||||
move 3 from 7 to 3
|
||||
move 3 from 4 to 9
|
||||
move 1 from 5 to 2
|
||||
move 4 from 4 to 2
|
||||
move 2 from 7 to 3
|
||||
move 4 from 1 to 6
|
||||
move 1 from 7 to 9
|
||||
move 11 from 9 to 5
|
||||
move 8 from 2 to 9
|
||||
move 6 from 9 to 6
|
||||
move 8 from 4 to 5
|
||||
move 14 from 5 to 6
|
||||
move 1 from 5 to 4
|
||||
move 3 from 5 to 1
|
||||
move 1 from 5 to 2
|
||||
move 2 from 6 to 4
|
||||
move 2 from 4 to 2
|
||||
move 1 from 9 to 2
|
||||
move 1 from 2 to 3
|
||||
move 1 from 9 to 3
|
||||
move 3 from 2 to 7
|
||||
move 7 from 6 to 7
|
||||
move 5 from 4 to 3
|
||||
move 23 from 6 to 1
|
||||
move 5 from 7 to 2
|
||||
move 22 from 1 to 6
|
||||
move 6 from 6 to 3
|
||||
move 6 from 2 to 4
|
||||
move 6 from 4 to 1
|
||||
move 3 from 7 to 8
|
||||
move 3 from 1 to 8
|
||||
move 4 from 3 to 2
|
||||
move 1 from 1 to 3
|
||||
move 3 from 3 to 1
|
||||
move 1 from 7 to 5
|
||||
move 1 from 6 to 5
|
||||
move 1 from 7 to 4
|
||||
move 4 from 6 to 9
|
||||
move 5 from 3 to 6
|
||||
move 2 from 2 to 1
|
||||
move 3 from 9 to 4
|
||||
move 11 from 1 to 9
|
||||
move 2 from 4 to 7
|
||||
move 4 from 6 to 1
|
||||
move 1 from 5 to 4
|
||||
move 5 from 8 to 9
|
||||
move 1 from 7 to 1
|
||||
move 3 from 2 to 7
|
||||
move 4 from 1 to 2
|
||||
move 3 from 4 to 2
|
||||
move 1 from 8 to 5
|
||||
move 1 from 5 to 4
|
||||
move 1 from 5 to 4
|
||||
move 5 from 6 to 1
|
||||
move 3 from 7 to 6
|
||||
move 5 from 2 to 8
|
||||
move 15 from 9 to 2
|
||||
move 1 from 3 to 9
|
||||
move 10 from 6 to 8
|
||||
move 1 from 4 to 9
|
||||
move 1 from 8 to 3
|
||||
move 1 from 4 to 6
|
||||
move 4 from 6 to 3
|
||||
move 2 from 9 to 7
|
||||
move 1 from 7 to 6
|
||||
move 1 from 1 to 6
|
||||
move 3 from 3 to 8
|
||||
move 2 from 7 to 8
|
||||
move 3 from 8 to 4
|
||||
move 12 from 2 to 9
|
||||
move 14 from 9 to 5
|
||||
move 12 from 8 to 2
|
||||
move 1 from 6 to 7
|
||||
move 8 from 3 to 1
|
||||
move 2 from 4 to 6
|
||||
move 1 from 3 to 6
|
||||
move 5 from 6 to 1
|
||||
move 17 from 1 to 2
|
||||
move 29 from 2 to 1
|
||||
move 1 from 8 to 5
|
||||
move 1 from 4 to 3
|
||||
move 1 from 8 to 5
|
||||
move 1 from 8 to 7
|
||||
move 5 from 2 to 1
|
||||
move 1 from 3 to 5
|
||||
move 1 from 6 to 4
|
||||
move 6 from 5 to 8
|
||||
move 1 from 4 to 9
|
||||
move 1 from 7 to 2
|
||||
move 1 from 2 to 6
|
||||
move 7 from 8 to 7
|
||||
move 1 from 6 to 9
|
||||
move 2 from 9 to 2
|
||||
move 2 from 2 to 8
|
||||
move 15 from 1 to 2
|
||||
move 2 from 8 to 3
|
||||
move 9 from 1 to 2
|
||||
move 24 from 2 to 7
|
||||
move 11 from 1 to 2
|
||||
move 1 from 3 to 1
|
||||
move 22 from 7 to 6
|
||||
move 6 from 5 to 2
|
||||
move 2 from 6 to 5
|
||||
move 1 from 1 to 9
|
||||
move 1 from 9 to 6
|
||||
move 6 from 5 to 1
|
||||
move 12 from 6 to 2
|
||||
move 3 from 1 to 5
|
||||
move 1 from 3 to 2
|
||||
move 25 from 2 to 6
|
||||
move 4 from 7 to 5
|
||||
move 8 from 5 to 4
|
||||
move 4 from 4 to 8
|
||||
move 1 from 1 to 8
|
||||
move 5 from 8 to 4
|
||||
move 4 from 4 to 1
|
||||
move 2 from 1 to 9
|
||||
move 20 from 6 to 8
|
||||
move 4 from 2 to 6
|
||||
move 19 from 8 to 7
|
||||
move 2 from 9 to 3
|
||||
move 1 from 8 to 2
|
||||
move 11 from 6 to 7
|
||||
move 3 from 1 to 2
|
||||
move 5 from 4 to 3
|
||||
move 1 from 1 to 3
|
||||
move 1 from 3 to 5
|
||||
move 2 from 2 to 8
|
||||
move 33 from 7 to 3
|
||||
move 1 from 5 to 3
|
||||
move 1 from 8 to 7
|
||||
move 1 from 7 to 4
|
||||
move 5 from 6 to 8
|
||||
move 2 from 7 to 6
|
||||
move 2 from 2 to 3
|
||||
move 1 from 2 to 5
|
||||
move 1 from 7 to 9
|
||||
move 1 from 5 to 7
|
||||
move 1 from 8 to 2
|
||||
move 1 from 4 to 3
|
||||
move 43 from 3 to 7
|
||||
move 1 from 3 to 8
|
||||
move 1 from 6 to 8
|
||||
move 8 from 7 to 5
|
||||
move 3 from 5 to 3
|
||||
move 1 from 6 to 4
|
||||
move 2 from 6 to 7
|
||||
move 4 from 8 to 7
|
||||
move 3 from 3 to 2
|
||||
move 1 from 9 to 6
|
||||
move 3 from 8 to 3
|
||||
move 1 from 6 to 7
|
||||
move 1 from 4 to 6
|
||||
move 1 from 3 to 7
|
||||
move 1 from 3 to 2
|
||||
move 5 from 2 to 5
|
||||
move 1 from 6 to 1
|
||||
move 1 from 3 to 2
|
||||
move 42 from 7 to 5
|
||||
move 44 from 5 to 4
|
||||
move 2 from 5 to 8
|
||||
move 1 from 7 to 3
|
||||
move 16 from 4 to 6
|
||||
move 3 from 5 to 9
|
|
@ -0,0 +1,151 @@
|
|||
"""
|
||||
--- Day 5: Supply Stacks ---
|
||||
|
||||
The expedition can depart as soon as the final supplies have been
|
||||
unloaded from the ships. Supplies are stored in stacks of marked crates,
|
||||
but because the needed supplies are buried under many other crates, the
|
||||
crates need to be rearranged.
|
||||
|
||||
The ship has a giant cargo crane capable of moving crates between
|
||||
stacks. To ensure none of the crates get crushed or fall over, the crane
|
||||
operator will rearrange them in a series of carefully-planned steps.
|
||||
After the crates are rearranged, the desired crates will be at the top
|
||||
of each stack.
|
||||
|
||||
The Elves don't want to interrupt the crane operator during this
|
||||
delicate procedure, but they forgot to ask her which crate will end up
|
||||
where, and they want to be ready to unload them as soon as possible so
|
||||
they can embark.
|
||||
|
||||
They do, however, have a drawing of the starting stacks of crates and
|
||||
the rearrangement procedure (your puzzle input). For example:
|
||||
|
||||
[D]
|
||||
[N] [C]
|
||||
[Z] [M] [P]
|
||||
1 2 3
|
||||
|
||||
move 1 from 2 to 1
|
||||
move 3 from 1 to 3
|
||||
move 2 from 2 to 1
|
||||
move 1 from 1 to 2
|
||||
|
||||
In this example, there are three stacks of crates. Stack 1 contains two
|
||||
crates: crate Z is on the bottom, and crate N is on top. Stack 2
|
||||
contains three crates; from bottom to top, they are crates M, C, and D.
|
||||
Finally, stack 3 contains a single crate, P.
|
||||
|
||||
Then, the rearrangement procedure is given. In each step of the
|
||||
procedure, a quantity of crates is moved from one stack to a different
|
||||
stack. In the first step of the above rearrangement procedure, one crate
|
||||
is moved from stack 2 to stack 1, resulting in this configuration:
|
||||
|
||||
[D]
|
||||
[N] [C]
|
||||
[Z] [M] [P]
|
||||
1 2 3
|
||||
|
||||
In the second step, three crates are moved from stack 1 to stack 3.
|
||||
Crates are moved one at a time, so the first crate to be moved (D) ends
|
||||
up below the second and third crates:
|
||||
|
||||
[Z]
|
||||
[N]
|
||||
[C] [D]
|
||||
[M] [P]
|
||||
1 2 3
|
||||
|
||||
Then, both crates are moved from stack 2 to stack 1. Again, because
|
||||
crates are moved one at a time, crate C ends up below crate M:
|
||||
|
||||
[Z]
|
||||
[N]
|
||||
[M] [D]
|
||||
[C] [P]
|
||||
1 2 3
|
||||
|
||||
Finally, one crate is moved from stack 1 to stack 2:
|
||||
|
||||
[Z]
|
||||
[N]
|
||||
[D]
|
||||
[C] [M] [P]
|
||||
1 2 3
|
||||
|
||||
The Elves just need to know which crate will end up on top of each
|
||||
stack; in this example, the top crates are C in stack 1, M in stack 2,
|
||||
and Z in stack 3, so you should combine these together and give the
|
||||
Elves the message CMZ.
|
||||
|
||||
After the rearrangement procedure completes, what crate ends up on top
|
||||
of each stack?
|
||||
"""
|
||||
import re
|
||||
import string
|
||||
|
||||
|
||||
def main():
|
||||
stacks = []
|
||||
|
||||
with open("input.txt", "r", encoding="utf-8") as f:
|
||||
# First, create the stacks.
|
||||
for line in f:
|
||||
if "[" in line and "]" in line:
|
||||
# A sample line could be:
|
||||
#
|
||||
# [Z] [M] [P]
|
||||
#
|
||||
# And we’re interested in the letters, meaning we need
|
||||
# the following indexes:
|
||||
#
|
||||
# [Z] [M] [P]
|
||||
# 1 5 9
|
||||
for i in range(1, 9999, 4):
|
||||
try:
|
||||
char = line[i]
|
||||
except IndexError:
|
||||
continue
|
||||
if char not in string.ascii_letters:
|
||||
continue
|
||||
|
||||
stack_index = int(((i - 1) / 4))
|
||||
while len(stacks) <= stack_index:
|
||||
stacks.append([])
|
||||
|
||||
stacks[stack_index].append(char)
|
||||
|
||||
# Stacks are loaded top to bottom from the input file, meaning
|
||||
# the lowest character is now the last entry of each array. To
|
||||
# be able to ``pop()`` the top crates off the stacks, we need
|
||||
# the highest characters last in our arrays, so we reverse them.
|
||||
for i, stack in enumerate(stacks):
|
||||
stack.reverse()
|
||||
stacks[i] = stack
|
||||
|
||||
# Now we need to replicate the movements described in the input
|
||||
# file.
|
||||
regex = re.compile(r"move (\d+) from (\d+) to (\d+)")
|
||||
f.seek(0)
|
||||
for line in f:
|
||||
match = regex.match(line)
|
||||
if match:
|
||||
amount = int(match[1])
|
||||
source_stack = int(match[2]) - 1
|
||||
target_stack = int(match[3]) - 1
|
||||
|
||||
print(f"Moving {amount} crates from {source_stack} to {target_stack}")
|
||||
while amount > 0:
|
||||
if len(stacks[source_stack]):
|
||||
stacks[target_stack].append(stacks[source_stack].pop())
|
||||
amount -= 1
|
||||
|
||||
answer = ""
|
||||
for stack in stacks:
|
||||
if len(stack):
|
||||
answer += stack.pop()
|
||||
|
||||
print(f"The top crates are {answer}")
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
|
@ -0,0 +1,135 @@
|
|||
"""
|
||||
--- Part Two ---
|
||||
|
||||
As you watch the crane operator expertly rearrange the crates, you
|
||||
notice the process isn't following your prediction.
|
||||
|
||||
Some mud was covering the writing on the side of the crane, and you
|
||||
quickly wipe it away. The crane isn't a CrateMover 9000 - it's a
|
||||
CrateMover 9001.
|
||||
|
||||
The CrateMover 9001 is notable for many new and exciting features: air
|
||||
conditioning, leather seats, an extra cup holder, and the ability to
|
||||
pick up and move multiple crates at once.
|
||||
|
||||
Again considering the example above, the crates begin in the same
|
||||
configuration:
|
||||
|
||||
[D]
|
||||
[N] [C]
|
||||
[Z] [M] [P]
|
||||
1 2 3
|
||||
|
||||
Moving a single crate from stack 2 to stack 1 behaves the same as
|
||||
before:
|
||||
|
||||
[D]
|
||||
[N] [C]
|
||||
[Z] [M] [P]
|
||||
1 2 3
|
||||
|
||||
However, the action of moving three crates from stack 1 to stack 3
|
||||
means that those three moved crates stay in the same order, resulting
|
||||
in this new configuration:
|
||||
|
||||
[D]
|
||||
[N]
|
||||
[C] [Z]
|
||||
[M] [P]
|
||||
1 2 3
|
||||
|
||||
Next, as both crates are moved from stack 2 to stack 1, they retain
|
||||
their order as well:
|
||||
|
||||
[D]
|
||||
[N]
|
||||
[C] [Z]
|
||||
[M] [P]
|
||||
1 2 3
|
||||
|
||||
Finally, a single crate is still moved from stack 1 to stack 2, but now
|
||||
it's crate C that gets moved:
|
||||
|
||||
[D]
|
||||
[N]
|
||||
[Z]
|
||||
[M] [C] [P]
|
||||
1 2 3
|
||||
|
||||
In this example, the CrateMover 9001 has put the crates in a totally
|
||||
different order: MCD.
|
||||
|
||||
Before the rearrangement process finishes, update your simulation so
|
||||
that the Elves know where they should stand to be ready to unload the
|
||||
final supplies. After the rearrangement procedure completes, what crate
|
||||
ends up on top of each stack?
|
||||
"""
|
||||
import re
|
||||
import string
|
||||
|
||||
|
||||
def main():
|
||||
stacks = []
|
||||
|
||||
with open("input.txt", "r", encoding="utf-8") as f:
|
||||
# First, create the stacks.
|
||||
for line in f:
|
||||
if "[" in line and "]" in line:
|
||||
# A sample line could be:
|
||||
#
|
||||
# [Z] [M] [P]
|
||||
#
|
||||
# And we’re interested in the letters, meaning we need
|
||||
# the following indexes:
|
||||
#
|
||||
# [Z] [M] [P]
|
||||
# 1 5 9
|
||||
for i in range(1, 9999, 4):
|
||||
try:
|
||||
char = line[i]
|
||||
except IndexError:
|
||||
continue
|
||||
if char not in string.ascii_letters:
|
||||
continue
|
||||
|
||||
stack_index = int(((i - 1) / 4))
|
||||
while len(stacks) <= stack_index:
|
||||
stacks.append([])
|
||||
|
||||
stacks[stack_index].append(char)
|
||||
|
||||
# Stacks are loaded top to bottom from the input file, meaning
|
||||
# the lowest character is now the last entry of each array. To
|
||||
# be able to ``pop()`` the top crates off the stacks, we need
|
||||
# the highest characters last in our arrays, so we reverse them.
|
||||
for i, stack in enumerate(stacks):
|
||||
stack.reverse()
|
||||
stacks[i] = stack
|
||||
|
||||
# Now we need to replicate the movements described in the input
|
||||
# file.
|
||||
regex = re.compile(r"move (\d+) from (\d+) to (\d+)")
|
||||
f.seek(0)
|
||||
for line in f:
|
||||
match = regex.match(line)
|
||||
if match:
|
||||
amount = int(match[1])
|
||||
source_stack = int(match[2]) - 1
|
||||
target_stack = int(match[3]) - 1
|
||||
|
||||
print(f"Moving {amount} crates from {source_stack} to {target_stack}")
|
||||
|
||||
pickup_index = amount * -1
|
||||
stacks[target_stack].extend(stacks[source_stack][pickup_index:])
|
||||
stacks[source_stack] = stacks[source_stack][:pickup_index]
|
||||
|
||||
answer = ""
|
||||
for stack in stacks:
|
||||
if len(stack):
|
||||
answer += stack.pop()
|
||||
|
||||
print(f"The top crates are {answer}")
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
|
@ -0,0 +1,9 @@
|
|||
[D]
|
||||
[N] [C]
|
||||
[Z] [M] [P]
|
||||
1 2 3
|
||||
|
||||
move 1 from 2 to 1
|
||||
move 3 from 1 to 3
|
||||
move 2 from 2 to 1
|
||||
move 1 from 1 to 2
|
Loading…
Reference in New Issue