adventofcode/2023/day4/main.py

43 lines
1.1 KiB
Python
Raw Normal View History

2023-12-04 15:44:00 +01:00
def part1(file: str):
2023-12-04 16:02:22 +01:00
array = []
2023-12-04 15:44:00 +01:00
with open(file) as f:
for line in f:
tmp = []
for el in [i.split(" ") for i in line.split(":")[1].split("|")]:
tmp.append([int(it) for it in el if len(it) > 0])
array.append(tmp)
total = 0
for card in array:
num_matches = len(set(card[0]) & set(card[1]))
if num_matches > 0:
total += 2 ** (num_matches - 1)
return total
def part2(file: str):
2023-12-04 16:15:17 +01:00
array = []
2023-12-04 15:44:00 +01:00
with open(file) as f:
for line in f:
2023-12-04 16:15:17 +01:00
tmp = []
for el in [i.split(" ") for i in line.split(":")[1].split("|")]:
tmp.append([int(it) for it in el if len(it) > 0])
array.append(tmp)
sets = [1 for _ in array]
for num_set, card in enumerate(array):
num_matches = len(set(card[0]) & set(card[1]))
for j in range(num_matches):
sets[num_set + 1 + j] += sets[num_set]
2023-12-04 15:44:00 +01:00
2023-12-04 16:15:17 +01:00
return sum(sets)
2023-12-04 15:44:00 +01:00
if __name__ == "__main__":
assert part1("example.txt") == 13
print(part1("input.txt"))
assert part2("example.txt") == 30
print(part2("input.txt"))