add solution day 5 in python

This commit is contained in:
Steven Wilson 2022-12-06 20:21:35 +00:00
parent 21dde873ff
commit 5073b706c6
3 changed files with 621 additions and 0 deletions

55
day05/day05-2.py Normal file
View File

@ -0,0 +1,55 @@
#!/usr/bin/env python3
import re
test = (""" [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""".splitlines())
def build_stacks(input):
number = (len(input[0]) // 4) + 1
stacks = [[] for i in range(number)]
for line in input:
if line[1] == "1":
break
for crate in range(0, number):
if( not line[(1 + (crate * 4))] == " " ):
stacks[crate].insert(0, line[(1 + (crate * 4))])
return stacks
def rearrange_stacks( input ):
stack = build_stacks( input )
for step in input:
if len(step) == 0 or not step[0] == "m":
next
else:
number, s1, s2 = re.findall(r"\b(\d+)", step)
# print("%s %s %s" % (number, s1, s2))
crates = stack[int(s1) - 1][-abs(int(number)):]
stack[int(s1) - 1] = stack[int(s1) - 1][0:-abs(int(number))]
stack[int(s2) -1] = stack[int(s2) -1] + crates
return stack
def read_stacks_top( stacks ):
top = list(map(list.pop, stacks))
print("".join(top))
if __name__ == "__main__":
file = open("input","r")
lines = file.read().splitlines()
# print(test)
# print(build_stacks(test)
# stacks_r = (rearrange_stacks(test))
# read_stacks_top(stacks_r)
stacks_r = rearrange_stacks(lines)
read_stacks_top(stacks_r)

55
day05/day05.py Normal file
View File

@ -0,0 +1,55 @@
#!/usr/bin/env python3
import re
test = (""" [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""".splitlines())
def build_stacks(input):
number = (len(input[0]) // 4) + 1
stacks = [[] for i in range(number)]
for line in input:
if line[1] == "1":
break
for crate in range(0, number):
if( not line[(1 + (crate * 4))] == " " ):
stacks[crate].insert(0, line[(1 + (crate * 4))])
return stacks
def rearrange_stacks( input ):
stack = build_stacks( input )
for step in input:
if len(step) == 0 or not step[0] == "m":
next
else:
number, s1, s2 = re.findall(r"\b(\d+)", step)
# print("%s %s %s" % (number, s1, s2))
for move in range(0, int(number)):
crate = stack[int(s1) - 1].pop()
stack[int(s2) -1].append(crate)
return stack
def read_stacks_top( stacks ):
top = list(map(list.pop, stacks))
print("".join(top))
if __name__ == "__main__":
file = open("input","r")
lines = file.read().splitlines()
# print(test)
# print(build_stacks(test)
# stacks_r = (rearrange_stacks(test))
# read_stacks_top(stacks_r)
stacks_r = rearrange_stacks(lines)
read_stacks_top(stacks_r)

511
day05/input Normal file
View File

@ -0,0 +1,511 @@
[T] [V] [W]
[V] [C] [P] [D] [B]
[J] [P] [R] [N] [B] [Z]
[W] [Q] [D] [M] [T] [L] [T]
[N] [J] [H] [B] [P] [T] [P] [L]
[R] [D] [F] [P] [R] [P] [R] [S] [G]
[M] [W] [J] [R] [V] [B] [J] [C] [S]
[S] [B] [B] [F] [H] [C] [B] [N] [L]
1 2 3 4 5 6 7 8 9
move 7 from 3 to 9
move 6 from 2 to 1
move 2 from 4 to 8
move 10 from 8 to 4
move 1 from 2 to 4
move 15 from 4 to 1
move 28 from 1 to 3
move 1 from 2 to 5
move 7 from 5 to 9
move 5 from 9 to 5
move 21 from 3 to 1
move 1 from 6 to 4
move 4 from 9 to 2
move 7 from 9 to 2
move 4 from 2 to 6
move 1 from 9 to 1
move 2 from 4 to 9
move 2 from 7 to 4
move 4 from 3 to 5
move 2 from 7 to 9
move 5 from 2 to 7
move 2 from 9 to 1
move 1 from 9 to 2
move 3 from 3 to 7
move 3 from 5 to 2
move 2 from 6 to 1
move 1 from 9 to 4
move 25 from 1 to 9
move 2 from 5 to 3
move 1 from 1 to 7
move 9 from 7 to 1
move 1 from 2 to 8
move 16 from 9 to 7
move 5 from 9 to 5
move 7 from 1 to 8
move 1 from 9 to 7
move 18 from 7 to 4
move 1 from 3 to 4
move 1 from 1 to 8
move 2 from 8 to 1
move 1 from 3 to 9
move 17 from 4 to 5
move 5 from 8 to 6
move 2 from 8 to 1
move 6 from 6 to 7
move 2 from 9 to 4
move 5 from 1 to 3
move 3 from 3 to 7
move 1 from 1 to 2
move 2 from 3 to 8
move 2 from 4 to 1
move 2 from 8 to 7
move 2 from 9 to 7
move 1 from 2 to 4
move 1 from 2 to 4
move 2 from 1 to 7
move 11 from 7 to 1
move 4 from 4 to 1
move 3 from 1 to 3
move 7 from 1 to 8
move 4 from 2 to 8
move 2 from 1 to 4
move 2 from 4 to 3
move 2 from 1 to 3
move 3 from 7 to 4
move 4 from 8 to 6
move 1 from 7 to 5
move 2 from 4 to 1
move 4 from 6 to 2
move 3 from 1 to 8
move 6 from 8 to 6
move 1 from 2 to 1
move 23 from 5 to 8
move 21 from 8 to 3
move 2 from 6 to 9
move 1 from 8 to 9
move 2 from 3 to 7
move 26 from 3 to 8
move 2 from 9 to 2
move 8 from 6 to 3
move 3 from 5 to 4
move 1 from 7 to 4
move 1 from 7 to 9
move 1 from 5 to 4
move 5 from 2 to 9
move 7 from 9 to 8
move 38 from 8 to 7
move 1 from 1 to 7
move 1 from 4 to 9
move 3 from 4 to 1
move 4 from 3 to 2
move 1 from 1 to 7
move 34 from 7 to 6
move 3 from 4 to 7
move 1 from 4 to 2
move 2 from 1 to 3
move 1 from 2 to 9
move 5 from 3 to 6
move 1 from 4 to 6
move 4 from 2 to 6
move 1 from 9 to 5
move 4 from 7 to 3
move 1 from 5 to 9
move 1 from 9 to 1
move 1 from 3 to 6
move 1 from 9 to 3
move 5 from 7 to 9
move 1 from 1 to 9
move 3 from 9 to 1
move 1 from 3 to 4
move 38 from 6 to 1
move 2 from 9 to 4
move 3 from 3 to 6
move 1 from 9 to 5
move 8 from 6 to 8
move 1 from 3 to 6
move 1 from 6 to 8
move 2 from 4 to 3
move 4 from 8 to 5
move 1 from 6 to 2
move 1 from 2 to 7
move 1 from 6 to 3
move 3 from 8 to 7
move 4 from 7 to 6
move 1 from 4 to 1
move 5 from 1 to 4
move 4 from 6 to 5
move 3 from 5 to 8
move 3 from 5 to 3
move 1 from 8 to 2
move 6 from 3 to 8
move 1 from 5 to 7
move 1 from 2 to 1
move 1 from 7 to 6
move 3 from 4 to 9
move 6 from 8 to 6
move 3 from 8 to 2
move 3 from 6 to 2
move 1 from 4 to 5
move 1 from 6 to 9
move 2 from 6 to 1
move 1 from 4 to 1
move 2 from 5 to 2
move 1 from 8 to 5
move 1 from 9 to 8
move 22 from 1 to 5
move 3 from 2 to 3
move 1 from 8 to 4
move 2 from 3 to 6
move 1 from 6 to 4
move 1 from 3 to 8
move 1 from 2 to 8
move 10 from 5 to 3
move 1 from 6 to 8
move 2 from 8 to 4
move 1 from 6 to 3
move 2 from 2 to 3
move 1 from 8 to 5
move 13 from 3 to 4
move 2 from 1 to 7
move 11 from 1 to 2
move 3 from 4 to 5
move 6 from 1 to 9
move 8 from 2 to 6
move 4 from 2 to 1
move 2 from 6 to 5
move 4 from 1 to 8
move 2 from 8 to 6
move 1 from 7 to 1
move 1 from 7 to 2
move 8 from 6 to 5
move 1 from 8 to 4
move 1 from 1 to 6
move 10 from 5 to 1
move 3 from 9 to 4
move 6 from 1 to 3
move 9 from 4 to 5
move 1 from 2 to 1
move 1 from 4 to 9
move 1 from 6 to 8
move 1 from 2 to 1
move 1 from 4 to 8
move 2 from 8 to 9
move 1 from 8 to 6
move 1 from 3 to 2
move 1 from 1 to 4
move 1 from 2 to 5
move 1 from 1 to 8
move 1 from 6 to 8
move 8 from 5 to 3
move 1 from 8 to 7
move 1 from 7 to 8
move 6 from 9 to 6
move 2 from 9 to 2
move 1 from 9 to 7
move 1 from 8 to 5
move 1 from 2 to 7
move 1 from 2 to 9
move 16 from 5 to 2
move 4 from 5 to 1
move 12 from 3 to 6
move 1 from 5 to 4
move 8 from 6 to 9
move 1 from 8 to 5
move 2 from 9 to 6
move 2 from 2 to 5
move 3 from 1 to 4
move 3 from 6 to 7
move 7 from 9 to 6
move 4 from 7 to 1
move 1 from 5 to 2
move 1 from 3 to 2
move 4 from 1 to 9
move 4 from 9 to 5
move 12 from 6 to 7
move 4 from 2 to 6
move 4 from 2 to 9
move 7 from 6 to 3
move 3 from 9 to 8
move 5 from 2 to 4
move 4 from 5 to 7
move 1 from 9 to 4
move 13 from 7 to 8
move 3 from 7 to 8
move 2 from 3 to 2
move 5 from 1 to 5
move 11 from 4 to 9
move 7 from 9 to 1
move 4 from 4 to 3
move 1 from 6 to 8
move 8 from 8 to 4
move 1 from 1 to 7
move 3 from 4 to 6
move 4 from 2 to 8
move 3 from 5 to 4
move 1 from 4 to 1
move 4 from 9 to 8
move 3 from 5 to 2
move 2 from 2 to 3
move 1 from 6 to 7
move 7 from 1 to 9
move 3 from 7 to 4
move 1 from 4 to 2
move 1 from 6 to 8
move 1 from 5 to 7
move 1 from 6 to 7
move 9 from 4 to 6
move 7 from 9 to 5
move 1 from 4 to 3
move 1 from 5 to 6
move 4 from 3 to 7
move 3 from 3 to 1
move 2 from 2 to 4
move 3 from 1 to 6
move 4 from 5 to 1
move 2 from 5 to 3
move 3 from 6 to 8
move 6 from 7 to 3
move 10 from 3 to 7
move 10 from 6 to 4
move 3 from 1 to 9
move 4 from 7 to 2
move 2 from 3 to 5
move 1 from 3 to 5
move 1 from 1 to 2
move 3 from 9 to 1
move 2 from 1 to 9
move 4 from 2 to 5
move 10 from 4 to 9
move 2 from 8 to 7
move 1 from 2 to 9
move 1 from 9 to 4
move 1 from 1 to 9
move 3 from 7 to 8
move 5 from 9 to 8
move 6 from 5 to 4
move 5 from 9 to 6
move 5 from 8 to 5
move 4 from 5 to 2
move 3 from 7 to 8
move 3 from 9 to 1
move 2 from 5 to 8
move 1 from 4 to 6
move 3 from 6 to 3
move 8 from 4 to 3
move 2 from 6 to 7
move 24 from 8 to 9
move 1 from 6 to 9
move 8 from 9 to 3
move 1 from 1 to 9
move 2 from 8 to 3
move 3 from 9 to 4
move 18 from 3 to 5
move 1 from 2 to 6
move 1 from 6 to 1
move 13 from 9 to 8
move 3 from 4 to 1
move 1 from 4 to 2
move 1 from 5 to 3
move 1 from 9 to 2
move 6 from 2 to 9
move 3 from 3 to 1
move 3 from 7 to 6
move 2 from 1 to 5
move 3 from 6 to 7
move 17 from 8 to 1
move 8 from 5 to 7
move 11 from 7 to 5
move 1 from 4 to 5
move 24 from 1 to 3
move 7 from 5 to 9
move 11 from 5 to 9
move 1 from 5 to 4
move 1 from 5 to 2
move 1 from 4 to 7
move 16 from 3 to 1
move 3 from 5 to 8
move 1 from 9 to 1
move 12 from 9 to 2
move 5 from 3 to 1
move 2 from 8 to 5
move 2 from 3 to 4
move 1 from 8 to 6
move 2 from 5 to 3
move 1 from 6 to 1
move 2 from 4 to 1
move 8 from 2 to 1
move 24 from 1 to 6
move 1 from 9 to 6
move 4 from 2 to 6
move 4 from 3 to 2
move 4 from 9 to 4
move 1 from 7 to 5
move 6 from 9 to 1
move 17 from 6 to 4
move 1 from 1 to 9
move 2 from 9 to 7
move 9 from 6 to 7
move 12 from 7 to 2
move 11 from 1 to 2
move 12 from 4 to 2
move 1 from 1 to 4
move 1 from 5 to 7
move 2 from 6 to 3
move 2 from 4 to 3
move 1 from 1 to 6
move 5 from 4 to 2
move 1 from 7 to 5
move 2 from 6 to 9
move 6 from 2 to 4
move 1 from 5 to 8
move 3 from 4 to 1
move 1 from 8 to 9
move 5 from 4 to 1
move 1 from 1 to 2
move 1 from 3 to 8
move 7 from 1 to 6
move 1 from 8 to 6
move 1 from 3 to 5
move 1 from 1 to 8
move 1 from 4 to 5
move 2 from 5 to 9
move 1 from 8 to 2
move 2 from 6 to 8
move 1 from 8 to 6
move 1 from 6 to 8
move 1 from 8 to 5
move 4 from 9 to 5
move 1 from 9 to 6
move 1 from 6 to 8
move 37 from 2 to 5
move 1 from 2 to 8
move 37 from 5 to 8
move 21 from 8 to 4
move 1 from 3 to 7
move 12 from 4 to 1
move 1 from 7 to 8
move 4 from 6 to 3
move 1 from 4 to 2
move 2 from 2 to 6
move 2 from 3 to 2
move 2 from 2 to 7
move 2 from 7 to 1
move 3 from 5 to 3
move 2 from 2 to 8
move 15 from 8 to 7
move 1 from 7 to 2
move 2 from 5 to 8
move 5 from 4 to 3
move 3 from 6 to 2
move 8 from 1 to 9
move 8 from 9 to 4
move 7 from 8 to 9
move 2 from 8 to 5
move 4 from 1 to 9
move 10 from 3 to 2
move 1 from 6 to 7
move 6 from 7 to 8
move 10 from 4 to 7
move 1 from 3 to 7
move 3 from 9 to 1
move 5 from 8 to 1
move 5 from 2 to 7
move 1 from 4 to 3
move 1 from 5 to 6
move 10 from 1 to 7
move 34 from 7 to 4
move 1 from 6 to 9
move 1 from 7 to 3
move 8 from 4 to 2
move 1 from 9 to 7
move 1 from 7 to 9
move 22 from 4 to 5
move 1 from 3 to 8
move 6 from 5 to 6
move 1 from 8 to 4
move 9 from 9 to 4
move 1 from 3 to 2
move 4 from 2 to 1
move 11 from 2 to 6
move 14 from 4 to 7
move 1 from 2 to 1
move 12 from 5 to 6
move 7 from 7 to 9
move 2 from 5 to 4
move 1 from 8 to 5
move 6 from 6 to 8
move 3 from 7 to 8
move 1 from 2 to 6
move 2 from 4 to 3
move 1 from 3 to 8
move 1 from 2 to 5
move 1 from 3 to 4
move 5 from 8 to 9
move 5 from 1 to 4
move 3 from 8 to 9
move 5 from 4 to 7
move 18 from 6 to 3
move 2 from 8 to 9
move 3 from 6 to 3
move 5 from 7 to 1
move 1 from 6 to 7
move 3 from 9 to 7
move 6 from 7 to 8
move 8 from 9 to 8
move 1 from 7 to 6
move 12 from 3 to 1
move 2 from 9 to 7
move 1 from 8 to 6
move 9 from 8 to 9
move 2 from 8 to 7
move 1 from 7 to 8
move 2 from 1 to 6
move 7 from 1 to 9
move 16 from 9 to 5
move 4 from 3 to 9
move 8 from 1 to 3
move 5 from 5 to 1
move 1 from 4 to 3
move 4 from 7 to 6
move 3 from 8 to 2
move 8 from 3 to 2
move 11 from 2 to 7
move 3 from 6 to 1
move 4 from 3 to 6
move 12 from 5 to 7
move 2 from 3 to 6
move 7 from 1 to 7
move 2 from 5 to 1
move 1 from 9 to 2
move 1 from 5 to 7
move 31 from 7 to 4
move 6 from 9 to 1
move 6 from 4 to 7
move 16 from 4 to 5
move 1 from 9 to 4
move 1 from 7 to 6
move 4 from 4 to 1
move 11 from 5 to 9
move 2 from 5 to 6
move 1 from 2 to 9
move 4 from 5 to 1
move 8 from 9 to 2
move 12 from 6 to 5
move 11 from 5 to 1
move 18 from 1 to 2
move 3 from 4 to 3
move 2 from 6 to 7
move 2 from 9 to 1
move 1 from 5 to 9
move 3 from 9 to 5
move 13 from 2 to 8
move 10 from 8 to 2
move 3 from 8 to 6
move 3 from 3 to 9
move 7 from 1 to 5
move 6 from 5 to 6
move 3 from 1 to 2
move 5 from 7 to 8
move 13 from 2 to 8
move 9 from 6 to 3