-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsumfind_v1.py
31 lines (24 loc) · 898 Bytes
/
sumfind_v1.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
import sys
from itertools import combinations
def find_combinations_to_target(numbers, target_sum):
found_combinations = []
for r in range(1, len(numbers) + 1):
for combo in combinations(numbers, r):
if round(sum(combo), 2) == target_sum:
found_combinations.append(combo)
return found_combinations
def main():
# The first command line argument is the target sum
target_sum = float(sys.argv[1])
# The rest of the arguments are the numbers to check
numbers = list(map(float, sys.argv[2:]))
# Find combinations
combinations_found = find_combinations_to_target(numbers, target_sum)
# Output the results
if combinations_found:
for combo in combinations_found:
print(combo)
else:
print("No combinations found that sum to the target.")
if __name__ == "__main__":
main()