TheAlgorithms-Python/project_euler/problem_032/sol32.py

59 lines
1.5 KiB
Python
Raw Normal View History

2019-10-04 04:47:39 +08:00
"""
We shall say that an n-digit number is pandigital if it makes use of all the
digits 1 to n exactly once; for example, the 5-digit number, 15234, is 1 through
5 pandigital.
The product 7254 is unusual, as the identity, 39 × 186 = 7254, containing
multiplicand, multiplier, and product is 1 through 9 pandigital.
Find the sum of all products whose multiplicand/multiplier/product identity can
be written as a 1 through 9 pandigital.
HINT: Some products can be obtained in more than one way so be sure to only
include it once in your sum.
"""
import itertools
def is_combination_valid(combination):
2019-10-04 04:47:39 +08:00
"""
Checks if a combination (a tuple of 9 digits)
is a valid product equation.
>>> is_combination_valid(('3', '9', '1', '8', '6', '7', '2', '5', '4'))
2019-10-04 04:47:39 +08:00
True
>>> is_combination_valid(('1', '2', '3', '4', '5', '6', '7', '8', '9'))
2019-10-04 04:47:39 +08:00
False
"""
return (
2019-10-05 13:14:13 +08:00
int("".join(combination[0:2])) * int("".join(combination[2:5]))
== int("".join(combination[5:9]))
2019-10-04 04:47:39 +08:00
) or (
2019-10-05 13:14:13 +08:00
int("".join(combination[0])) * int("".join(combination[1:5]))
== int("".join(combination[5:9]))
2019-10-04 04:47:39 +08:00
)
def solution():
"""
Finds the sum of all products whose multiplicand/multiplier/product identity
can be written as a 1 through 9 pandigital
>>> solution()
45228
"""
return sum(
{
int("".join(pandigital[5:9]))
for pandigital in itertools.permutations("123456789")
if is_combination_valid(pandigital)
}
2019-10-04 04:47:39 +08:00
)
2019-10-05 13:14:13 +08:00
2019-10-04 04:47:39 +08:00
if __name__ == "__main__":
print(solution())