34 lines
825 B
Python
34 lines
825 B
Python
#!/usr/bin/env python
|
|
# 2024 - Advent Of Code 7
|
|
|
|
# file = 'input_example.txt'
|
|
file = 'input.txt'
|
|
|
|
# pylint: disable=consider-using-with
|
|
input_lines = [line.strip('\n') for line in open(file, encoding="utf-8")]
|
|
|
|
def next_op(a, i, t):
|
|
if i < len(nums):
|
|
r1 = next_op(a + nums[i], i + 1, t)
|
|
r2 = next_op(a * nums[i], i + 1, t)
|
|
return r1 or r2
|
|
|
|
# print(f'end at {i}, value {a}')
|
|
if a == target:
|
|
return True
|
|
return False
|
|
|
|
good_values = []
|
|
for line in input_lines:
|
|
target, numbers = line.split(':')
|
|
target = int(target)
|
|
nums = [int(x) for x in numbers.split(' ') if x != '']
|
|
# print(f'{target=}')
|
|
# print(f'{nums=}')
|
|
|
|
index = 1
|
|
if next_op(nums[0], index, target):
|
|
# print(f'{target} OK')
|
|
good_values.append(target)
|
|
|
|
print(sum(good_values))
|