-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathday12.py
More file actions
91 lines (84 loc) · 2.04 KB
/
day12.py
File metadata and controls
91 lines (84 loc) · 2.04 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import sys
def wrap(angle):
return (360 + angle) % 360
def left(wp, val):
x0, y0 = wp
if val == 90:
x1 = -y0
y1 = x0
elif val == 180:
x1 = -x0
y1 = -y0
elif val == 270:
x1 = y0
y1 = -x0
else:
assert False
return [x1, y1]
def right(wp, val):
x0, y0 = wp
if val == 90:
x1 = y0
y1 = -x0
elif val == 180:
x1 = -x0
y1 = -y0
elif val == 270:
x1 = -y0
y1 = x0
else:
assert False
return [x1, y1]
def part1(commands):
angle2cmd = {0: 'E', 90: 'N', 180: 'W', 270: 'S'}
angle, x, y = 0, 0, 0
for cmd, val in commands:
cmd = angle2cmd[angle] if cmd == 'F' else cmd
if cmd == 'L':
angle = wrap(angle + val)
elif cmd == 'R':
angle = wrap(angle - val)
elif cmd == 'N':
y += val
elif cmd == 'S':
y -= val
elif cmd == 'E':
x += val
elif cmd == 'W':
x -= val
else:
assert False
return abs(x) + abs(y)
def part2(commands):
ship = [0, 0]
waypoint = [10, 1]
for cmd, val in commands:
if cmd == 'L':
waypoint = left(waypoint, val)
elif cmd == 'R':
waypoint = right(waypoint, val)
elif cmd == 'F':
ship[0] += waypoint[0] * val
ship[1] += waypoint[1] * val
elif cmd == 'N':
waypoint[1] += val
elif cmd == 'S':
waypoint[1] -= val
elif cmd == 'E':
waypoint[0] += val
elif cmd == 'W':
waypoint[0] -= val
else:
assert False
return abs(ship[0]) + abs(ship[1])
def main(inp):
with open(inp) as f:
lines = f.read().splitlines()
commands = [(x[0], int(x[1:])) for x in lines]
res1 = part1(commands)
res2 = part2(commands)
return res1, res2
if __name__ == '__main__':
res1, res2 = main('../input/input12.txt')
print('day12.1:', res1)
print('day12.2:', res2)