-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathday5.py
64 lines (54 loc) · 1.71 KB
/
day5.py
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
"""
https://adventofcode.com/2020/day/5
"""
from day4 import get_list
def decipher_row_num(s: str, n_rows: int, n_char) -> int:
rows = s[:n_char]
max_position = n_rows - 1
min_position = 0
for r in rows[:-1]:
if r == 'F':
max_position = max_position - (max_position - min_position) // 2 - 1
elif r == 'B':
min_position = min_position + (max_position - min_position) // 2 + 1
if rows[-1] == 'F':
return min_position
elif rows[-1] == 'B':
return max_position
return -1
def decipher_column_num(s: str, n_cl: int, n_char) -> int:
columns = s[len(s) - n_char:]
max_position = n_cl - 1
min_position = 0
for cl in columns[:-1]:
if cl == 'R':
min_position = min_position + (max_position - min_position) // 2 + 1
elif cl == 'L':
max_position = max_position - (max_position - min_position) // 2 - 1
if columns[-1] == 'R':
return max_position
elif columns[-1] == 'L':
return min_position
return -1
def count_seat_ID(row: int, column: int, multiplier: int):
return row * multiplier + column
def find_seat(IDs: list) -> int:
ordered = sorted(IDs)
for i in range(len(ordered) - 2):
i1 = ordered[i]
i2 = ordered[i + 1]
if i2 - i1 == 2:
return (i2 + i1) // 2
return -1
if __name__ == '__main__':
boarding_passes = get_list('input5.txt')
print(boarding_passes)
IDs = []
for bp in boarding_passes:
row = decipher_row_num(bp, 128, 7)
column = decipher_column_num(bp, 8, 3)
IDs.append(count_seat_ID(row, column, 8))
print(IDs)
print(max(IDs))
my_seat = find_seat(IDs)
print(my_seat)