d5: python
parent
a1e4ad6038
commit
67130ccc37
|
@ -0,0 +1,4 @@
|
|||
if command -v nix-shell &> /dev/null
|
||||
then
|
||||
use flake
|
||||
fi
|
|
@ -0,0 +1,10 @@
|
|||
[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
|
||||
|
|
@ -0,0 +1,513 @@
|
|||
[P] [L] [T]
|
||||
[L] [M] [G] [G] [S]
|
||||
[M] [Q] [W] [H] [R] [G]
|
||||
[N] [F] [M] [D] [V] [R] [N]
|
||||
[W] [G] [Q] [P] [J] [F] [M] [C]
|
||||
[V] [H] [B] [F] [H] [M] [B] [H] [B]
|
||||
[B] [Q] [D] [T] [T] [B] [N] [L] [D]
|
||||
[H] [M] [N] [Z] [M] [C] [M] [P] [P]
|
||||
1 2 3 4 5 6 7 8 9
|
||||
|
||||
move 8 from 3 to 2
|
||||
move 1 from 9 to 5
|
||||
move 5 from 4 to 7
|
||||
move 6 from 1 to 4
|
||||
move 8 from 6 to 8
|
||||
move 8 from 4 to 5
|
||||
move 4 from 9 to 5
|
||||
move 4 from 7 to 9
|
||||
move 7 from 7 to 2
|
||||
move 4 from 5 to 2
|
||||
move 11 from 8 to 3
|
||||
move 3 from 9 to 7
|
||||
move 11 from 2 to 8
|
||||
move 13 from 8 to 4
|
||||
move 11 from 5 to 6
|
||||
move 8 from 2 to 4
|
||||
move 1 from 5 to 4
|
||||
move 1 from 3 to 2
|
||||
move 2 from 2 to 1
|
||||
move 2 from 8 to 5
|
||||
move 3 from 7 to 5
|
||||
move 1 from 4 to 7
|
||||
move 9 from 6 to 7
|
||||
move 1 from 6 to 5
|
||||
move 1 from 1 to 4
|
||||
move 3 from 1 to 9
|
||||
move 15 from 4 to 3
|
||||
move 2 from 4 to 1
|
||||
move 1 from 1 to 9
|
||||
move 3 from 4 to 5
|
||||
move 1 from 4 to 1
|
||||
move 1 from 7 to 2
|
||||
move 1 from 6 to 3
|
||||
move 5 from 7 to 1
|
||||
move 19 from 3 to 9
|
||||
move 7 from 1 to 2
|
||||
move 24 from 9 to 7
|
||||
move 23 from 7 to 1
|
||||
move 1 from 4 to 6
|
||||
move 3 from 7 to 3
|
||||
move 1 from 6 to 1
|
||||
move 6 from 2 to 1
|
||||
move 21 from 1 to 9
|
||||
move 5 from 3 to 8
|
||||
move 2 from 2 to 5
|
||||
move 10 from 9 to 5
|
||||
move 1 from 2 to 1
|
||||
move 5 from 1 to 3
|
||||
move 6 from 3 to 4
|
||||
move 1 from 2 to 8
|
||||
move 3 from 5 to 2
|
||||
move 4 from 9 to 3
|
||||
move 13 from 5 to 9
|
||||
move 2 from 7 to 2
|
||||
move 3 from 4 to 7
|
||||
move 1 from 7 to 8
|
||||
move 5 from 1 to 3
|
||||
move 1 from 7 to 5
|
||||
move 1 from 8 to 1
|
||||
move 2 from 2 to 7
|
||||
move 19 from 9 to 2
|
||||
move 5 from 2 to 3
|
||||
move 7 from 5 to 9
|
||||
move 1 from 1 to 9
|
||||
move 5 from 9 to 2
|
||||
move 4 from 9 to 3
|
||||
move 20 from 3 to 9
|
||||
move 1 from 3 to 9
|
||||
move 3 from 7 to 3
|
||||
move 16 from 2 to 3
|
||||
move 12 from 3 to 4
|
||||
move 2 from 2 to 5
|
||||
move 1 from 2 to 4
|
||||
move 2 from 4 to 1
|
||||
move 4 from 8 to 1
|
||||
move 15 from 9 to 3
|
||||
move 2 from 5 to 3
|
||||
move 3 from 2 to 8
|
||||
move 5 from 8 to 5
|
||||
move 7 from 3 to 4
|
||||
move 2 from 9 to 6
|
||||
move 15 from 3 to 1
|
||||
move 3 from 1 to 8
|
||||
move 3 from 9 to 5
|
||||
move 9 from 4 to 1
|
||||
move 3 from 3 to 5
|
||||
move 2 from 6 to 5
|
||||
move 9 from 1 to 3
|
||||
move 1 from 9 to 4
|
||||
move 1 from 5 to 2
|
||||
move 3 from 8 to 5
|
||||
move 10 from 1 to 6
|
||||
move 12 from 4 to 8
|
||||
move 1 from 2 to 7
|
||||
move 2 from 5 to 6
|
||||
move 1 from 1 to 4
|
||||
move 7 from 3 to 6
|
||||
move 1 from 7 to 2
|
||||
move 2 from 4 to 9
|
||||
move 3 from 1 to 7
|
||||
move 1 from 9 to 8
|
||||
move 1 from 2 to 3
|
||||
move 3 from 1 to 7
|
||||
move 5 from 8 to 2
|
||||
move 5 from 7 to 1
|
||||
move 9 from 6 to 8
|
||||
move 6 from 6 to 9
|
||||
move 8 from 8 to 6
|
||||
move 1 from 7 to 4
|
||||
move 5 from 2 to 4
|
||||
move 7 from 5 to 1
|
||||
move 5 from 8 to 9
|
||||
move 11 from 6 to 7
|
||||
move 9 from 9 to 1
|
||||
move 2 from 7 to 5
|
||||
move 1 from 9 to 5
|
||||
move 1 from 3 to 6
|
||||
move 3 from 4 to 6
|
||||
move 1 from 8 to 2
|
||||
move 2 from 3 to 6
|
||||
move 6 from 5 to 2
|
||||
move 3 from 5 to 9
|
||||
move 3 from 2 to 1
|
||||
move 1 from 4 to 3
|
||||
move 3 from 2 to 7
|
||||
move 1 from 8 to 9
|
||||
move 1 from 2 to 8
|
||||
move 8 from 7 to 5
|
||||
move 1 from 7 to 8
|
||||
move 3 from 5 to 6
|
||||
move 5 from 5 to 2
|
||||
move 1 from 4 to 1
|
||||
move 1 from 3 to 2
|
||||
move 4 from 1 to 5
|
||||
move 4 from 2 to 6
|
||||
move 6 from 1 to 2
|
||||
move 5 from 9 to 3
|
||||
move 2 from 5 to 3
|
||||
move 3 from 3 to 6
|
||||
move 10 from 6 to 4
|
||||
move 4 from 8 to 5
|
||||
move 5 from 5 to 1
|
||||
move 21 from 1 to 7
|
||||
move 3 from 2 to 9
|
||||
move 1 from 5 to 2
|
||||
move 4 from 2 to 9
|
||||
move 8 from 4 to 8
|
||||
move 1 from 2 to 1
|
||||
move 7 from 8 to 2
|
||||
move 2 from 6 to 1
|
||||
move 2 from 1 to 5
|
||||
move 1 from 1 to 5
|
||||
move 4 from 3 to 7
|
||||
move 1 from 9 to 3
|
||||
move 4 from 6 to 3
|
||||
move 1 from 3 to 8
|
||||
move 1 from 3 to 4
|
||||
move 2 from 2 to 6
|
||||
move 2 from 9 to 7
|
||||
move 14 from 7 to 8
|
||||
move 10 from 8 to 7
|
||||
move 3 from 4 to 6
|
||||
move 5 from 2 to 3
|
||||
move 3 from 9 to 8
|
||||
move 3 from 3 to 4
|
||||
move 1 from 2 to 4
|
||||
move 1 from 9 to 4
|
||||
move 1 from 9 to 5
|
||||
move 1 from 5 to 2
|
||||
move 3 from 5 to 7
|
||||
move 1 from 4 to 6
|
||||
move 5 from 3 to 8
|
||||
move 1 from 6 to 8
|
||||
move 5 from 7 to 6
|
||||
move 14 from 8 to 5
|
||||
move 2 from 6 to 7
|
||||
move 18 from 7 to 2
|
||||
move 3 from 6 to 1
|
||||
move 5 from 5 to 4
|
||||
move 5 from 6 to 2
|
||||
move 7 from 2 to 1
|
||||
move 1 from 8 to 4
|
||||
move 1 from 5 to 1
|
||||
move 8 from 1 to 9
|
||||
move 10 from 4 to 3
|
||||
move 8 from 5 to 3
|
||||
move 1 from 4 to 3
|
||||
move 2 from 1 to 5
|
||||
move 1 from 5 to 3
|
||||
move 5 from 3 to 1
|
||||
move 1 from 1 to 3
|
||||
move 5 from 1 to 6
|
||||
move 13 from 3 to 1
|
||||
move 3 from 9 to 4
|
||||
move 2 from 9 to 6
|
||||
move 5 from 6 to 5
|
||||
move 6 from 5 to 1
|
||||
move 7 from 7 to 9
|
||||
move 7 from 9 to 6
|
||||
move 1 from 9 to 3
|
||||
move 1 from 7 to 9
|
||||
move 3 from 9 to 1
|
||||
move 12 from 2 to 7
|
||||
move 7 from 6 to 2
|
||||
move 22 from 1 to 7
|
||||
move 1 from 6 to 5
|
||||
move 4 from 7 to 6
|
||||
move 1 from 5 to 6
|
||||
move 2 from 4 to 1
|
||||
move 1 from 4 to 1
|
||||
move 23 from 7 to 9
|
||||
move 4 from 6 to 2
|
||||
move 4 from 7 to 3
|
||||
move 1 from 1 to 9
|
||||
move 6 from 2 to 1
|
||||
move 1 from 7 to 2
|
||||
move 7 from 2 to 8
|
||||
move 2 from 3 to 8
|
||||
move 3 from 1 to 9
|
||||
move 1 from 2 to 8
|
||||
move 5 from 8 to 3
|
||||
move 3 from 2 to 1
|
||||
move 2 from 7 to 8
|
||||
move 10 from 9 to 8
|
||||
move 4 from 1 to 3
|
||||
move 14 from 3 to 4
|
||||
move 7 from 4 to 5
|
||||
move 1 from 6 to 9
|
||||
move 5 from 5 to 8
|
||||
move 1 from 6 to 4
|
||||
move 6 from 9 to 4
|
||||
move 3 from 8 to 4
|
||||
move 1 from 5 to 1
|
||||
move 3 from 4 to 3
|
||||
move 9 from 4 to 3
|
||||
move 5 from 3 to 6
|
||||
move 5 from 1 to 5
|
||||
move 4 from 6 to 2
|
||||
move 8 from 9 to 2
|
||||
move 2 from 6 to 5
|
||||
move 3 from 4 to 7
|
||||
move 2 from 2 to 7
|
||||
move 2 from 5 to 4
|
||||
move 3 from 5 to 9
|
||||
move 3 from 4 to 2
|
||||
move 10 from 2 to 5
|
||||
move 1 from 9 to 8
|
||||
move 2 from 2 to 9
|
||||
move 3 from 7 to 2
|
||||
move 1 from 2 to 9
|
||||
move 13 from 5 to 1
|
||||
move 2 from 2 to 7
|
||||
move 8 from 9 to 2
|
||||
move 1 from 4 to 6
|
||||
move 1 from 9 to 5
|
||||
move 14 from 8 to 4
|
||||
move 7 from 4 to 5
|
||||
move 4 from 7 to 5
|
||||
move 2 from 3 to 8
|
||||
move 4 from 1 to 5
|
||||
move 2 from 5 to 4
|
||||
move 6 from 5 to 6
|
||||
move 7 from 2 to 5
|
||||
move 1 from 2 to 6
|
||||
move 1 from 5 to 2
|
||||
move 2 from 2 to 8
|
||||
move 2 from 1 to 3
|
||||
move 8 from 4 to 7
|
||||
move 1 from 4 to 3
|
||||
move 6 from 1 to 6
|
||||
move 7 from 3 to 9
|
||||
move 3 from 7 to 1
|
||||
move 2 from 8 to 7
|
||||
move 7 from 6 to 9
|
||||
move 2 from 3 to 6
|
||||
move 6 from 8 to 3
|
||||
move 9 from 5 to 3
|
||||
move 2 from 7 to 8
|
||||
move 2 from 6 to 4
|
||||
move 7 from 6 to 9
|
||||
move 5 from 3 to 8
|
||||
move 10 from 9 to 1
|
||||
move 11 from 1 to 8
|
||||
move 1 from 3 to 2
|
||||
move 4 from 5 to 6
|
||||
move 2 from 6 to 2
|
||||
move 2 from 7 to 9
|
||||
move 3 from 1 to 7
|
||||
move 6 from 3 to 9
|
||||
move 2 from 7 to 2
|
||||
move 2 from 6 to 9
|
||||
move 1 from 5 to 9
|
||||
move 11 from 9 to 8
|
||||
move 1 from 4 to 5
|
||||
move 6 from 9 to 8
|
||||
move 31 from 8 to 9
|
||||
move 1 from 3 to 6
|
||||
move 1 from 7 to 1
|
||||
move 1 from 4 to 3
|
||||
move 1 from 5 to 2
|
||||
move 1 from 1 to 8
|
||||
move 1 from 8 to 9
|
||||
move 1 from 7 to 3
|
||||
move 11 from 9 to 6
|
||||
move 2 from 3 to 1
|
||||
move 2 from 3 to 5
|
||||
move 1 from 5 to 4
|
||||
move 1 from 4 to 1
|
||||
move 6 from 8 to 3
|
||||
move 1 from 1 to 4
|
||||
move 1 from 4 to 6
|
||||
move 2 from 3 to 6
|
||||
move 17 from 9 to 2
|
||||
move 23 from 2 to 9
|
||||
move 14 from 9 to 4
|
||||
move 1 from 1 to 7
|
||||
move 1 from 5 to 6
|
||||
move 8 from 6 to 2
|
||||
move 1 from 3 to 2
|
||||
move 4 from 9 to 8
|
||||
move 5 from 4 to 7
|
||||
move 3 from 7 to 2
|
||||
move 1 from 1 to 2
|
||||
move 2 from 9 to 4
|
||||
move 3 from 6 to 9
|
||||
move 8 from 4 to 9
|
||||
move 2 from 4 to 2
|
||||
move 4 from 7 to 2
|
||||
move 1 from 7 to 9
|
||||
move 4 from 6 to 2
|
||||
move 16 from 2 to 1
|
||||
move 2 from 3 to 2
|
||||
move 18 from 9 to 8
|
||||
move 1 from 4 to 2
|
||||
move 1 from 6 to 8
|
||||
move 1 from 3 to 9
|
||||
move 3 from 9 to 5
|
||||
move 4 from 9 to 8
|
||||
move 6 from 2 to 8
|
||||
move 1 from 5 to 1
|
||||
move 4 from 2 to 8
|
||||
move 1 from 5 to 1
|
||||
move 17 from 1 to 4
|
||||
move 1 from 5 to 8
|
||||
move 10 from 4 to 3
|
||||
move 10 from 3 to 1
|
||||
move 4 from 4 to 9
|
||||
move 1 from 4 to 6
|
||||
move 1 from 4 to 8
|
||||
move 38 from 8 to 1
|
||||
move 27 from 1 to 5
|
||||
move 1 from 8 to 2
|
||||
move 1 from 6 to 3
|
||||
move 1 from 4 to 8
|
||||
move 1 from 8 to 4
|
||||
move 14 from 1 to 9
|
||||
move 1 from 3 to 1
|
||||
move 1 from 5 to 1
|
||||
move 1 from 2 to 5
|
||||
move 2 from 5 to 4
|
||||
move 17 from 5 to 8
|
||||
move 3 from 4 to 9
|
||||
move 2 from 9 to 1
|
||||
move 3 from 5 to 7
|
||||
move 3 from 7 to 4
|
||||
move 2 from 4 to 7
|
||||
move 12 from 1 to 4
|
||||
move 1 from 7 to 4
|
||||
move 1 from 7 to 6
|
||||
move 1 from 6 to 9
|
||||
move 11 from 4 to 3
|
||||
move 1 from 5 to 3
|
||||
move 11 from 3 to 9
|
||||
move 1 from 3 to 2
|
||||
move 3 from 5 to 4
|
||||
move 1 from 2 to 4
|
||||
move 1 from 5 to 8
|
||||
move 13 from 9 to 3
|
||||
move 16 from 9 to 1
|
||||
move 4 from 8 to 9
|
||||
move 2 from 1 to 4
|
||||
move 1 from 9 to 1
|
||||
move 1 from 9 to 7
|
||||
move 1 from 7 to 2
|
||||
move 6 from 8 to 3
|
||||
move 8 from 4 to 2
|
||||
move 4 from 9 to 6
|
||||
move 3 from 2 to 3
|
||||
move 3 from 6 to 1
|
||||
move 3 from 8 to 6
|
||||
move 1 from 6 to 8
|
||||
move 3 from 6 to 4
|
||||
move 11 from 3 to 5
|
||||
move 4 from 8 to 2
|
||||
move 6 from 3 to 5
|
||||
move 3 from 5 to 1
|
||||
move 2 from 8 to 3
|
||||
move 14 from 5 to 3
|
||||
move 4 from 3 to 4
|
||||
move 6 from 3 to 5
|
||||
move 3 from 2 to 9
|
||||
move 4 from 1 to 8
|
||||
move 3 from 9 to 6
|
||||
move 2 from 6 to 9
|
||||
move 6 from 4 to 3
|
||||
move 15 from 1 to 4
|
||||
move 1 from 6 to 7
|
||||
move 5 from 5 to 1
|
||||
move 11 from 3 to 1
|
||||
move 2 from 9 to 7
|
||||
move 1 from 5 to 6
|
||||
move 2 from 1 to 3
|
||||
move 7 from 2 to 6
|
||||
move 4 from 8 to 1
|
||||
move 8 from 4 to 2
|
||||
move 3 from 6 to 4
|
||||
move 5 from 1 to 4
|
||||
move 17 from 4 to 8
|
||||
move 3 from 3 to 7
|
||||
move 4 from 3 to 4
|
||||
move 4 from 4 to 2
|
||||
move 9 from 8 to 7
|
||||
move 1 from 3 to 8
|
||||
move 10 from 2 to 4
|
||||
move 1 from 6 to 2
|
||||
move 2 from 8 to 4
|
||||
move 2 from 6 to 9
|
||||
move 2 from 6 to 2
|
||||
move 1 from 2 to 3
|
||||
move 3 from 1 to 4
|
||||
move 1 from 3 to 2
|
||||
move 1 from 9 to 3
|
||||
move 1 from 9 to 7
|
||||
move 4 from 8 to 4
|
||||
move 10 from 4 to 8
|
||||
move 5 from 4 to 3
|
||||
move 1 from 2 to 8
|
||||
move 5 from 3 to 7
|
||||
move 3 from 7 to 8
|
||||
move 3 from 4 to 3
|
||||
move 8 from 7 to 2
|
||||
move 8 from 7 to 8
|
||||
move 1 from 3 to 2
|
||||
move 3 from 2 to 8
|
||||
move 9 from 2 to 5
|
||||
move 12 from 1 to 7
|
||||
move 21 from 8 to 3
|
||||
move 5 from 8 to 6
|
||||
move 8 from 7 to 5
|
||||
move 6 from 7 to 4
|
||||
move 12 from 5 to 7
|
||||
move 1 from 8 to 5
|
||||
move 2 from 4 to 2
|
||||
move 1 from 7 to 6
|
||||
move 14 from 3 to 8
|
||||
move 5 from 6 to 2
|
||||
move 7 from 2 to 6
|
||||
move 6 from 8 to 4
|
||||
move 11 from 7 to 4
|
||||
move 8 from 3 to 7
|
||||
move 4 from 5 to 7
|
||||
move 9 from 8 to 2
|
||||
move 6 from 4 to 1
|
||||
move 2 from 5 to 2
|
||||
move 1 from 7 to 2
|
||||
move 11 from 2 to 3
|
||||
move 1 from 2 to 1
|
||||
move 7 from 4 to 1
|
||||
move 5 from 6 to 8
|
||||
move 1 from 2 to 3
|
||||
move 2 from 8 to 7
|
||||
move 14 from 3 to 7
|
||||
move 15 from 7 to 6
|
||||
move 4 from 4 to 6
|
||||
move 2 from 8 to 3
|
||||
move 12 from 1 to 3
|
||||
move 1 from 8 to 2
|
||||
move 1 from 2 to 3
|
||||
move 1 from 3 to 9
|
||||
move 1 from 9 to 7
|
||||
move 1 from 1 to 4
|
||||
move 18 from 6 to 8
|
||||
move 3 from 3 to 2
|
||||
move 17 from 8 to 3
|
||||
move 3 from 7 to 6
|
||||
move 3 from 2 to 6
|
||||
move 25 from 3 to 7
|
||||
move 2 from 4 to 1
|
||||
move 9 from 6 to 5
|
||||
move 2 from 3 to 1
|
||||
move 1 from 3 to 9
|
||||
move 5 from 5 to 2
|
||||
move 1 from 8 to 3
|
||||
move 2 from 4 to 7
|
||||
move 1 from 9 to 4
|
||||
move 1 from 6 to 7
|
||||
move 2 from 5 to 2
|
||||
move 2 from 4 to 8
|
||||
move 2 from 5 to 8
|
||||
move 5 from 7 to 9
|
||||
move 27 from 7 to 5
|
||||
move 2 from 9 to 6
|
||||
|
|
@ -0,0 +1,43 @@
|
|||
{
|
||||
"nodes": {
|
||||
"flake-utils": {
|
||||
"locked": {
|
||||
"lastModified": 1667395993,
|
||||
"narHash": "sha256-nuEHfE/LcWyuSWnS8t12N1wc105Qtau+/OdUAjtQ0rA=",
|
||||
"owner": "numtide",
|
||||
"repo": "flake-utils",
|
||||
"rev": "5aed5285a952e0b949eb3ba02c12fa4fcfef535f",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "numtide",
|
||||
"repo": "flake-utils",
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"nixpkgs": {
|
||||
"locked": {
|
||||
"lastModified": 1670064435,
|
||||
"narHash": "sha256-+ELoY30UN+Pl3Yn7RWRPabykwebsVK/kYE9JsIsUMxQ=",
|
||||
"owner": "nixos",
|
||||
"repo": "nixpkgs",
|
||||
"rev": "61a8a98e6d557e6dd7ed0cdb54c3a3e3bbc5e25c",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "nixos",
|
||||
"ref": "nixos-unstable",
|
||||
"repo": "nixpkgs",
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"root": {
|
||||
"inputs": {
|
||||
"flake-utils": "flake-utils",
|
||||
"nixpkgs": "nixpkgs"
|
||||
}
|
||||
}
|
||||
},
|
||||
"root": "root",
|
||||
"version": 7
|
||||
}
|
|
@ -0,0 +1,50 @@
|
|||
{
|
||||
description = "D4 AOC with Lua!";
|
||||
inputs = {
|
||||
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
|
||||
flake-utils.url = "github:numtide/flake-utils";
|
||||
};
|
||||
outputs = { nixpkgs, flake-utils, ... } @ inputs:
|
||||
flake-utils.lib.eachSystem flake-utils.lib.defaultSystems (sys:
|
||||
let
|
||||
overlays = [ ];
|
||||
pkgs = import nixpkgs { system = sys; overlays = overlays; };
|
||||
shellHookAfter = ''
|
||||
echo "The input files should be placed under ./data/{submission,example}.txt"
|
||||
echo "This problem shares one input between two parts"
|
||||
'';
|
||||
py_pkgs = [ pkgs.python310 ];
|
||||
lua_pkgs = [ (pkgs.lua.withPackages (luapkgs: [ luapkgs.busted luapkgs.luafilesystem ])) ];
|
||||
fennel_pkgs = [ pkgs.lua.withPackages (luapkgs: [ luapkgs.fennel ]) ];
|
||||
in
|
||||
{
|
||||
# Jack of all trades
|
||||
devShell = pkgs.mkShell {
|
||||
nativeBuildInputs = py_pkgs ++ fennel_pkgs;
|
||||
shellHook = ''
|
||||
echo "> Default runtime. This contains both lua and python3 env"
|
||||
echo "Run ./run-py.sh for Python's output and ./run-lua.sh for Lua's output"
|
||||
'' + shellHookAfter;
|
||||
};
|
||||
devShells = {
|
||||
# nix develop ./#lua
|
||||
# lua = pkgs.mkShell {
|
||||
# nativeBuildInputs = lua_pkgs;
|
||||
# shellHook = ''
|
||||
# echo "> Lua runtime"
|
||||
# echo "Run ./run-lua.sh to see the output of the solution"
|
||||
# '' + shellHookAfter;
|
||||
# };
|
||||
# nix develop ./#python
|
||||
python = pkgs.mkShell {
|
||||
nativeBuildInputs = py_pkgs;
|
||||
shellHook = ''
|
||||
echo "> Python3 runtime"
|
||||
echo "Run ./run-py.sh to see the output of the solution"
|
||||
'' + shellHookAfter;
|
||||
|
||||
};
|
||||
};
|
||||
}
|
||||
);
|
||||
}
|
|
@ -0,0 +1,7 @@
|
|||
#!/usr/bin/env sh
|
||||
echo "example"
|
||||
python3 ./src/d5.py ./data/example.txt
|
||||
|
||||
echo "submission"
|
||||
python3 ./src/d5.py ./data/submission.txt
|
||||
|
|
@ -0,0 +1,77 @@
|
|||
#!/usr/bin/env python3
|
||||
from typing import Literal, Union, Iterable, Optional
|
||||
from dataclasses import dataclass
|
||||
|
||||
@dataclass
|
||||
class MoveInsn:
|
||||
how_many: int
|
||||
from_crate: int
|
||||
to_crate: int
|
||||
|
||||
@classmethod
|
||||
def from_line(cls, line: str):
|
||||
tokens = line.strip().split()
|
||||
v = map(lambda v: int(tokens[v]), [1, 3, 5]) # indices of "number" token
|
||||
return cls(*v) # this is basically calls the constructor
|
||||
|
||||
def part1(crates: list[list[str]], insns: list[MoveInsn]) -> str:
|
||||
for move in insns:
|
||||
for _ in range(move.how_many):
|
||||
crates[move.to_crate - 1].append(crates[move.from_crate - 1].pop())
|
||||
return "".join([crate[-1] for crate in crates])
|
||||
|
||||
def part2(crates: list[list[str]], insns: list[MoveInsn]) -> str:
|
||||
for move in insns:
|
||||
pops =([crates[move.from_crate - 1].pop() for _ in range(move.how_many)])
|
||||
crates[move.to_crate - 1].extend(reversed(pops))
|
||||
return "".join([crate[-1] for crate in crates])
|
||||
|
||||
|
||||
def copy_crates(crate_stacks: list[list[str]]):
|
||||
return [c[:] for c in crate_stacks]
|
||||
|
||||
def main(input_lines: Iterable[str]):
|
||||
# Assuming each crate name is single char
|
||||
PARSE_CRATE = 0
|
||||
PARSE_INSNS = 1
|
||||
|
||||
parse_state = 0
|
||||
crates_str = []
|
||||
crate_stacks: Optional[list[list[str]]] = None
|
||||
moves = []
|
||||
|
||||
for _line in input_lines:
|
||||
if len(_line.strip()) == 0:
|
||||
# neovim copy-paste doesn't work too well, excuse me
|
||||
continue
|
||||
match parse_state:
|
||||
case 0:
|
||||
crates = [s.strip() for s in _line.split()]
|
||||
if crates[0] == "1":
|
||||
parse_state = PARSE_INSNS
|
||||
# Begin propagating
|
||||
crate_stacks = [[] for _ in range(len(crates))]
|
||||
for crate_line in reversed(crates_str):
|
||||
crate_decls = [crate_line[i] for i in range(1, len(crate_line), 4)]
|
||||
for crate, stack in zip(crate_decls, crate_stacks):
|
||||
if crate == ' ':
|
||||
continue
|
||||
stack.append(crate)
|
||||
# print(crate_stacks)
|
||||
else:
|
||||
crates_str.append(_line)
|
||||
pass
|
||||
case 1:
|
||||
moves.append(MoveInsn.from_line(_line))
|
||||
# print(moves)
|
||||
pass
|
||||
|
||||
assert crate_stacks is not None, "input must indicate crates input"
|
||||
print("part1", part1(copy_crates(crate_stacks), moves))
|
||||
print("part2", part2(copy_crates(crate_stacks), moves))
|
||||
pass
|
||||
|
||||
if __name__ == "__main__":
|
||||
import sys
|
||||
with open(sys.argv[1], "r") as f:
|
||||
main(f)
|
Loading…
Reference in New Issue