Day 12, part 1
This commit is contained in:
parent
97e4d5284c
commit
30156f0229
3 changed files with 835 additions and 0 deletions
771
2020/12/data.txt
Normal file
771
2020/12/data.txt
Normal file
|
@ -0,0 +1,771 @@
|
||||||
|
F92
|
||||||
|
R180
|
||||||
|
S1
|
||||||
|
F64
|
||||||
|
R90
|
||||||
|
S1
|
||||||
|
E1
|
||||||
|
F11
|
||||||
|
N4
|
||||||
|
R180
|
||||||
|
S3
|
||||||
|
E3
|
||||||
|
F55
|
||||||
|
R90
|
||||||
|
N1
|
||||||
|
E4
|
||||||
|
L180
|
||||||
|
F9
|
||||||
|
N3
|
||||||
|
R90
|
||||||
|
W4
|
||||||
|
N4
|
||||||
|
F36
|
||||||
|
L90
|
||||||
|
F50
|
||||||
|
E3
|
||||||
|
F9
|
||||||
|
E5
|
||||||
|
S1
|
||||||
|
W2
|
||||||
|
E4
|
||||||
|
R180
|
||||||
|
N3
|
||||||
|
F18
|
||||||
|
N2
|
||||||
|
S5
|
||||||
|
W1
|
||||||
|
F41
|
||||||
|
E3
|
||||||
|
N4
|
||||||
|
F66
|
||||||
|
R270
|
||||||
|
F22
|
||||||
|
N5
|
||||||
|
E4
|
||||||
|
N1
|
||||||
|
L90
|
||||||
|
W1
|
||||||
|
N1
|
||||||
|
R90
|
||||||
|
F87
|
||||||
|
E1
|
||||||
|
N4
|
||||||
|
E1
|
||||||
|
L90
|
||||||
|
E5
|
||||||
|
L180
|
||||||
|
F84
|
||||||
|
S5
|
||||||
|
F65
|
||||||
|
N2
|
||||||
|
W1
|
||||||
|
F65
|
||||||
|
N3
|
||||||
|
L90
|
||||||
|
R90
|
||||||
|
E1
|
||||||
|
L180
|
||||||
|
S1
|
||||||
|
F60
|
||||||
|
E3
|
||||||
|
L90
|
||||||
|
F22
|
||||||
|
E5
|
||||||
|
F32
|
||||||
|
S1
|
||||||
|
L90
|
||||||
|
E2
|
||||||
|
S2
|
||||||
|
W5
|
||||||
|
N2
|
||||||
|
E5
|
||||||
|
F60
|
||||||
|
L180
|
||||||
|
W3
|
||||||
|
F49
|
||||||
|
S5
|
||||||
|
F84
|
||||||
|
N5
|
||||||
|
F78
|
||||||
|
W5
|
||||||
|
S3
|
||||||
|
L90
|
||||||
|
S3
|
||||||
|
F83
|
||||||
|
L90
|
||||||
|
E1
|
||||||
|
L90
|
||||||
|
E1
|
||||||
|
F99
|
||||||
|
W1
|
||||||
|
L90
|
||||||
|
W2
|
||||||
|
L90
|
||||||
|
S1
|
||||||
|
R180
|
||||||
|
F8
|
||||||
|
E2
|
||||||
|
R180
|
||||||
|
N2
|
||||||
|
F66
|
||||||
|
N5
|
||||||
|
L90
|
||||||
|
E1
|
||||||
|
F76
|
||||||
|
W3
|
||||||
|
F23
|
||||||
|
F79
|
||||||
|
N3
|
||||||
|
E1
|
||||||
|
R90
|
||||||
|
N5
|
||||||
|
F33
|
||||||
|
N2
|
||||||
|
L180
|
||||||
|
F97
|
||||||
|
R90
|
||||||
|
L90
|
||||||
|
S5
|
||||||
|
F99
|
||||||
|
W5
|
||||||
|
L90
|
||||||
|
F47
|
||||||
|
L90
|
||||||
|
E4
|
||||||
|
F99
|
||||||
|
S4
|
||||||
|
R90
|
||||||
|
E2
|
||||||
|
S2
|
||||||
|
L90
|
||||||
|
F33
|
||||||
|
E2
|
||||||
|
F71
|
||||||
|
R90
|
||||||
|
N1
|
||||||
|
N2
|
||||||
|
W3
|
||||||
|
L90
|
||||||
|
W4
|
||||||
|
S1
|
||||||
|
R90
|
||||||
|
F27
|
||||||
|
L270
|
||||||
|
W5
|
||||||
|
F49
|
||||||
|
W3
|
||||||
|
F41
|
||||||
|
L90
|
||||||
|
F23
|
||||||
|
L90
|
||||||
|
S1
|
||||||
|
F11
|
||||||
|
L90
|
||||||
|
W3
|
||||||
|
N1
|
||||||
|
W4
|
||||||
|
L90
|
||||||
|
N4
|
||||||
|
W2
|
||||||
|
L90
|
||||||
|
S3
|
||||||
|
W4
|
||||||
|
L180
|
||||||
|
W4
|
||||||
|
R180
|
||||||
|
W4
|
||||||
|
F49
|
||||||
|
E3
|
||||||
|
S2
|
||||||
|
F64
|
||||||
|
S4
|
||||||
|
F61
|
||||||
|
E3
|
||||||
|
L180
|
||||||
|
W1
|
||||||
|
N2
|
||||||
|
W2
|
||||||
|
F64
|
||||||
|
R90
|
||||||
|
S4
|
||||||
|
E5
|
||||||
|
N1
|
||||||
|
L270
|
||||||
|
E3
|
||||||
|
F22
|
||||||
|
E2
|
||||||
|
R90
|
||||||
|
S5
|
||||||
|
F57
|
||||||
|
N2
|
||||||
|
F78
|
||||||
|
L270
|
||||||
|
W1
|
||||||
|
N4
|
||||||
|
L90
|
||||||
|
S4
|
||||||
|
F71
|
||||||
|
S2
|
||||||
|
L90
|
||||||
|
E1
|
||||||
|
L180
|
||||||
|
F4
|
||||||
|
N1
|
||||||
|
W4
|
||||||
|
L90
|
||||||
|
N5
|
||||||
|
F98
|
||||||
|
N3
|
||||||
|
L90
|
||||||
|
W2
|
||||||
|
L180
|
||||||
|
F54
|
||||||
|
W1
|
||||||
|
R90
|
||||||
|
W3
|
||||||
|
F67
|
||||||
|
L90
|
||||||
|
W2
|
||||||
|
R180
|
||||||
|
F79
|
||||||
|
N4
|
||||||
|
F30
|
||||||
|
L90
|
||||||
|
N4
|
||||||
|
R180
|
||||||
|
L90
|
||||||
|
S5
|
||||||
|
F7
|
||||||
|
N2
|
||||||
|
F26
|
||||||
|
S5
|
||||||
|
F43
|
||||||
|
E3
|
||||||
|
N3
|
||||||
|
L180
|
||||||
|
F57
|
||||||
|
W4
|
||||||
|
L90
|
||||||
|
E5
|
||||||
|
F100
|
||||||
|
S2
|
||||||
|
F86
|
||||||
|
L180
|
||||||
|
W3
|
||||||
|
S5
|
||||||
|
W1
|
||||||
|
S3
|
||||||
|
L180
|
||||||
|
S2
|
||||||
|
S5
|
||||||
|
W4
|
||||||
|
L90
|
||||||
|
F73
|
||||||
|
R90
|
||||||
|
F14
|
||||||
|
E2
|
||||||
|
F99
|
||||||
|
R90
|
||||||
|
R90
|
||||||
|
E5
|
||||||
|
N1
|
||||||
|
R90
|
||||||
|
N1
|
||||||
|
N4
|
||||||
|
R180
|
||||||
|
S4
|
||||||
|
L90
|
||||||
|
F98
|
||||||
|
W2
|
||||||
|
L90
|
||||||
|
F100
|
||||||
|
R180
|
||||||
|
W4
|
||||||
|
F92
|
||||||
|
E1
|
||||||
|
L180
|
||||||
|
S3
|
||||||
|
F94
|
||||||
|
E4
|
||||||
|
N5
|
||||||
|
R90
|
||||||
|
S3
|
||||||
|
W4
|
||||||
|
F86
|
||||||
|
S5
|
||||||
|
R90
|
||||||
|
E2
|
||||||
|
F6
|
||||||
|
E2
|
||||||
|
F75
|
||||||
|
N1
|
||||||
|
L90
|
||||||
|
W4
|
||||||
|
F2
|
||||||
|
E1
|
||||||
|
N4
|
||||||
|
E1
|
||||||
|
L90
|
||||||
|
W4
|
||||||
|
F17
|
||||||
|
N2
|
||||||
|
R90
|
||||||
|
E5
|
||||||
|
R90
|
||||||
|
N1
|
||||||
|
W1
|
||||||
|
R180
|
||||||
|
W4
|
||||||
|
R180
|
||||||
|
F97
|
||||||
|
E5
|
||||||
|
N2
|
||||||
|
L90
|
||||||
|
F27
|
||||||
|
N1
|
||||||
|
W5
|
||||||
|
R90
|
||||||
|
N1
|
||||||
|
F98
|
||||||
|
R90
|
||||||
|
N2
|
||||||
|
F12
|
||||||
|
W5
|
||||||
|
S1
|
||||||
|
F86
|
||||||
|
N3
|
||||||
|
W3
|
||||||
|
F71
|
||||||
|
L180
|
||||||
|
W1
|
||||||
|
R90
|
||||||
|
W3
|
||||||
|
S4
|
||||||
|
E2
|
||||||
|
S5
|
||||||
|
W3
|
||||||
|
R90
|
||||||
|
E4
|
||||||
|
R90
|
||||||
|
W1
|
||||||
|
N3
|
||||||
|
F11
|
||||||
|
W4
|
||||||
|
E4
|
||||||
|
F67
|
||||||
|
E2
|
||||||
|
F15
|
||||||
|
W5
|
||||||
|
N4
|
||||||
|
W1
|
||||||
|
R90
|
||||||
|
L90
|
||||||
|
W4
|
||||||
|
F16
|
||||||
|
N4
|
||||||
|
F87
|
||||||
|
L180
|
||||||
|
F73
|
||||||
|
L180
|
||||||
|
E5
|
||||||
|
R90
|
||||||
|
F96
|
||||||
|
N5
|
||||||
|
W1
|
||||||
|
F28
|
||||||
|
R90
|
||||||
|
W5
|
||||||
|
S3
|
||||||
|
S3
|
||||||
|
E5
|
||||||
|
R180
|
||||||
|
E4
|
||||||
|
F4
|
||||||
|
L90
|
||||||
|
E3
|
||||||
|
E4
|
||||||
|
S5
|
||||||
|
W3
|
||||||
|
L180
|
||||||
|
F57
|
||||||
|
R90
|
||||||
|
N2
|
||||||
|
F78
|
||||||
|
N2
|
||||||
|
L90
|
||||||
|
S1
|
||||||
|
R90
|
||||||
|
W4
|
||||||
|
S1
|
||||||
|
L90
|
||||||
|
N5
|
||||||
|
F60
|
||||||
|
R90
|
||||||
|
S4
|
||||||
|
F42
|
||||||
|
R90
|
||||||
|
W2
|
||||||
|
F31
|
||||||
|
R180
|
||||||
|
N2
|
||||||
|
S2
|
||||||
|
F91
|
||||||
|
S4
|
||||||
|
R90
|
||||||
|
N2
|
||||||
|
L180
|
||||||
|
N1
|
||||||
|
E4
|
||||||
|
F72
|
||||||
|
E3
|
||||||
|
E3
|
||||||
|
N2
|
||||||
|
L90
|
||||||
|
N1
|
||||||
|
L90
|
||||||
|
F83
|
||||||
|
S1
|
||||||
|
R90
|
||||||
|
N5
|
||||||
|
E4
|
||||||
|
F53
|
||||||
|
N3
|
||||||
|
E5
|
||||||
|
S3
|
||||||
|
E4
|
||||||
|
F93
|
||||||
|
W2
|
||||||
|
F53
|
||||||
|
L90
|
||||||
|
E2
|
||||||
|
L90
|
||||||
|
W2
|
||||||
|
F96
|
||||||
|
R90
|
||||||
|
E3
|
||||||
|
L90
|
||||||
|
S5
|
||||||
|
F31
|
||||||
|
R90
|
||||||
|
R90
|
||||||
|
F98
|
||||||
|
F91
|
||||||
|
W2
|
||||||
|
N3
|
||||||
|
F69
|
||||||
|
R90
|
||||||
|
F51
|
||||||
|
R90
|
||||||
|
N1
|
||||||
|
E2
|
||||||
|
R90
|
||||||
|
S1
|
||||||
|
R180
|
||||||
|
E5
|
||||||
|
N5
|
||||||
|
W5
|
||||||
|
F34
|
||||||
|
W1
|
||||||
|
F60
|
||||||
|
R90
|
||||||
|
F53
|
||||||
|
R90
|
||||||
|
F62
|
||||||
|
R90
|
||||||
|
S4
|
||||||
|
F95
|
||||||
|
W5
|
||||||
|
E2
|
||||||
|
F84
|
||||||
|
R90
|
||||||
|
E2
|
||||||
|
F54
|
||||||
|
E2
|
||||||
|
F5
|
||||||
|
R90
|
||||||
|
F32
|
||||||
|
L90
|
||||||
|
E2
|
||||||
|
S2
|
||||||
|
L180
|
||||||
|
F31
|
||||||
|
E2
|
||||||
|
L90
|
||||||
|
N5
|
||||||
|
W2
|
||||||
|
L90
|
||||||
|
F53
|
||||||
|
R90
|
||||||
|
S1
|
||||||
|
R90
|
||||||
|
F49
|
||||||
|
R90
|
||||||
|
S3
|
||||||
|
L90
|
||||||
|
F76
|
||||||
|
F31
|
||||||
|
S1
|
||||||
|
F13
|
||||||
|
R90
|
||||||
|
W1
|
||||||
|
S1
|
||||||
|
R90
|
||||||
|
W2
|
||||||
|
L180
|
||||||
|
E2
|
||||||
|
R90
|
||||||
|
E2
|
||||||
|
N1
|
||||||
|
W1
|
||||||
|
S1
|
||||||
|
E1
|
||||||
|
S4
|
||||||
|
L90
|
||||||
|
N2
|
||||||
|
E2
|
||||||
|
R90
|
||||||
|
S4
|
||||||
|
L90
|
||||||
|
N5
|
||||||
|
L90
|
||||||
|
W4
|
||||||
|
S2
|
||||||
|
W1
|
||||||
|
L90
|
||||||
|
E4
|
||||||
|
R90
|
||||||
|
W2
|
||||||
|
S1
|
||||||
|
L90
|
||||||
|
N5
|
||||||
|
F63
|
||||||
|
R90
|
||||||
|
W1
|
||||||
|
F20
|
||||||
|
L90
|
||||||
|
F86
|
||||||
|
S4
|
||||||
|
S4
|
||||||
|
E2
|
||||||
|
F92
|
||||||
|
F90
|
||||||
|
W4
|
||||||
|
F94
|
||||||
|
E1
|
||||||
|
N5
|
||||||
|
F30
|
||||||
|
W3
|
||||||
|
N3
|
||||||
|
L180
|
||||||
|
W5
|
||||||
|
F52
|
||||||
|
R270
|
||||||
|
E5
|
||||||
|
R90
|
||||||
|
N4
|
||||||
|
W4
|
||||||
|
F10
|
||||||
|
N1
|
||||||
|
F16
|
||||||
|
N1
|
||||||
|
F31
|
||||||
|
S4
|
||||||
|
L90
|
||||||
|
F81
|
||||||
|
N1
|
||||||
|
L90
|
||||||
|
W2
|
||||||
|
F84
|
||||||
|
L90
|
||||||
|
F79
|
||||||
|
L90
|
||||||
|
W5
|
||||||
|
L90
|
||||||
|
F90
|
||||||
|
R90
|
||||||
|
E2
|
||||||
|
L90
|
||||||
|
F25
|
||||||
|
N5
|
||||||
|
S1
|
||||||
|
F12
|
||||||
|
R90
|
||||||
|
F34
|
||||||
|
R90
|
||||||
|
F4
|
||||||
|
E4
|
||||||
|
L90
|
||||||
|
S1
|
||||||
|
F70
|
||||||
|
R90
|
||||||
|
F22
|
||||||
|
R90
|
||||||
|
F67
|
||||||
|
R90
|
||||||
|
F40
|
||||||
|
W1
|
||||||
|
S3
|
||||||
|
L180
|
||||||
|
N2
|
||||||
|
E4
|
||||||
|
S4
|
||||||
|
F98
|
||||||
|
R180
|
||||||
|
F16
|
||||||
|
S2
|
||||||
|
W4
|
||||||
|
S1
|
||||||
|
F70
|
||||||
|
L90
|
||||||
|
N3
|
||||||
|
E3
|
||||||
|
L270
|
||||||
|
W4
|
||||||
|
L90
|
||||||
|
W5
|
||||||
|
R180
|
||||||
|
W5
|
||||||
|
N4
|
||||||
|
R90
|
||||||
|
W4
|
||||||
|
F5
|
||||||
|
L270
|
||||||
|
E3
|
||||||
|
L90
|
||||||
|
E5
|
||||||
|
F50
|
||||||
|
S3
|
||||||
|
F51
|
||||||
|
E1
|
||||||
|
S5
|
||||||
|
F95
|
||||||
|
R90
|
||||||
|
L90
|
||||||
|
S2
|
||||||
|
F75
|
||||||
|
R90
|
||||||
|
W2
|
||||||
|
F70
|
||||||
|
E2
|
||||||
|
F52
|
||||||
|
W4
|
||||||
|
E1
|
||||||
|
L180
|
||||||
|
F72
|
||||||
|
N2
|
||||||
|
F5
|
||||||
|
E2
|
||||||
|
F94
|
||||||
|
R180
|
||||||
|
F7
|
||||||
|
E3
|
||||||
|
N2
|
||||||
|
R90
|
||||||
|
W1
|
||||||
|
N4
|
||||||
|
R90
|
||||||
|
S1
|
||||||
|
W4
|
||||||
|
L270
|
||||||
|
W1
|
||||||
|
W1
|
||||||
|
N2
|
||||||
|
E1
|
||||||
|
F31
|
||||||
|
N1
|
||||||
|
W4
|
||||||
|
S5
|
||||||
|
L90
|
||||||
|
E1
|
||||||
|
R180
|
||||||
|
F50
|
||||||
|
N1
|
||||||
|
W2
|
||||||
|
F66
|
||||||
|
N2
|
||||||
|
L90
|
||||||
|
R90
|
||||||
|
W1
|
||||||
|
E5
|
||||||
|
L90
|
||||||
|
E2
|
||||||
|
R180
|
||||||
|
F63
|
||||||
|
N4
|
||||||
|
N3
|
||||||
|
F87
|
||||||
|
W4
|
||||||
|
L90
|
||||||
|
F85
|
||||||
|
N3
|
||||||
|
F93
|
||||||
|
S2
|
||||||
|
F95
|
||||||
|
N5
|
||||||
|
L180
|
||||||
|
S3
|
||||||
|
R90
|
||||||
|
W5
|
||||||
|
L180
|
||||||
|
W1
|
||||||
|
L90
|
||||||
|
S4
|
||||||
|
F68
|
||||||
|
L180
|
||||||
|
S4
|
||||||
|
R180
|
||||||
|
E2
|
||||||
|
L180
|
||||||
|
E3
|
||||||
|
R180
|
||||||
|
S5
|
||||||
|
F88
|
||||||
|
N1
|
||||||
|
R90
|
||||||
|
S3
|
||||||
|
E5
|
||||||
|
S5
|
||||||
|
E1
|
||||||
|
N5
|
||||||
|
E2
|
||||||
|
S1
|
||||||
|
W5
|
||||||
|
F62
|
||||||
|
R90
|
||||||
|
F39
|
||||||
|
L180
|
||||||
|
N3
|
||||||
|
F42
|
||||||
|
E4
|
||||||
|
N5
|
||||||
|
R90
|
||||||
|
W5
|
||||||
|
S2
|
||||||
|
F43
|
||||||
|
W4
|
||||||
|
F94
|
||||||
|
R90
|
||||||
|
F85
|
||||||
|
N5
|
||||||
|
F7
|
||||||
|
L180
|
||||||
|
W4
|
||||||
|
L180
|
||||||
|
E4
|
||||||
|
F44
|
||||||
|
N2
|
||||||
|
W2
|
||||||
|
N3
|
||||||
|
L180
|
||||||
|
E3
|
||||||
|
N1
|
||||||
|
S2
|
||||||
|
W4
|
||||||
|
N5
|
||||||
|
R180
|
||||||
|
F78
|
||||||
|
E5
|
||||||
|
L90
|
||||||
|
W4
|
||||||
|
F77
|
59
2020/12/main.py
Normal file
59
2020/12/main.py
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
class Ferry:
|
||||||
|
def __init__(self):
|
||||||
|
self.heading = 90 # east
|
||||||
|
self.pos_north = 0
|
||||||
|
self.pos_east = 0
|
||||||
|
|
||||||
|
def load(self, filename):
|
||||||
|
with open(filename, "r", encoding="utf-8") as f:
|
||||||
|
for line in f:
|
||||||
|
data = line.rstrip()
|
||||||
|
self.process(data)
|
||||||
|
|
||||||
|
def rotate(self, degrees):
|
||||||
|
self.heading += degrees
|
||||||
|
while self.heading < 0:
|
||||||
|
self.heading += 360
|
||||||
|
while self.heading >= 360:
|
||||||
|
self.heading -= 360
|
||||||
|
|
||||||
|
def process(self, input):
|
||||||
|
command = input[:1]
|
||||||
|
value = int(input[1:])
|
||||||
|
|
||||||
|
if command == "N":
|
||||||
|
self.pos_north += value
|
||||||
|
elif command == "S":
|
||||||
|
self.pos_north -= value
|
||||||
|
elif command == "E":
|
||||||
|
self.pos_east += value
|
||||||
|
elif command == "W":
|
||||||
|
self.pos_east -= value
|
||||||
|
elif command == "L":
|
||||||
|
self.rotate(-value)
|
||||||
|
elif command == "R":
|
||||||
|
self.rotate(value)
|
||||||
|
elif command == "F":
|
||||||
|
if self.heading == 0:
|
||||||
|
self.pos_north += value
|
||||||
|
elif self.heading == 90:
|
||||||
|
self.pos_east += value
|
||||||
|
elif self.heading == 180:
|
||||||
|
self.pos_north -= value
|
||||||
|
elif self.heading == 270:
|
||||||
|
self.pos_east -= value
|
||||||
|
else:
|
||||||
|
raise Exception(self.heading)
|
||||||
|
else:
|
||||||
|
raise Exception(command)
|
||||||
|
|
||||||
|
print(input, self.pos_east, self.pos_north)
|
||||||
|
|
||||||
|
def get_md(self):
|
||||||
|
return abs(self.pos_east) + abs(self.pos_north)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
f = Ferry()
|
||||||
|
f.load("data.txt")
|
||||||
|
md = f.get_md()
|
||||||
|
print(f"Manhattan distance is {md}")
|
5
2020/12/test.txt
Normal file
5
2020/12/test.txt
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
F10
|
||||||
|
N3
|
||||||
|
F7
|
||||||
|
R90
|
||||||
|
F11
|
Loading…
Add table
Reference in a new issue