advent-of-code/2020/16/solution1.py
2020-12-18 15:18:55 +01:00

49 lines
1.0 KiB
Python

import re
rules = []
my_ticket = None
tickets = []
with open('input', 'r') as f:
line = f.readline() # heading rules
while line != '\n':
rules.append(line)
line = f.readline()
f.readline() # heading my_ticket
my_ticket = f.readline()
f.readline() # newline
f.readline() # heading tickets
tickets = f.readlines()
def parse_ticket(raw):
return list(map(int, raw.split(',')))
def parse_rule(raw):
return list(map(int, re.findall('[0-9]+', raw)))
def in_range(num, lower, upper):
return num >= lower and num <= upper
my_ticket = parse_ticket(my_ticket)
tickets = list(map(parse_ticket, tickets))
rules = list(map(parse_rule, rules))
error_rate = 0
for ticket in tickets:
for num in ticket:
matches_rule = False
for rule in rules:
minA, maxA, minB, maxB = rule
if in_range(num, minA, maxA) or in_range(num, minB, maxB):
matches_rule = True
if not matches_rule:
error_rate += num
print(error_rate)