mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
62 lines
1.7 KiB
Python
62 lines
1.7 KiB
Python
|
"""
|
|||
|
Project Euler Problem 135: https://projecteuler.net/problem=135
|
|||
|
|
|||
|
Given the positive integers, x, y, and z,
|
|||
|
are consecutive terms of an arithmetic progression,
|
|||
|
the least value of the positive integer, n,
|
|||
|
for which the equation,
|
|||
|
x2 − y2 − z2 = n, has exactly two solutions is n = 27:
|
|||
|
|
|||
|
342 − 272 − 202 = 122 − 92 − 62 = 27
|
|||
|
|
|||
|
It turns out that n = 1155 is the least value
|
|||
|
which has exactly ten solutions.
|
|||
|
|
|||
|
How many values of n less than one million
|
|||
|
have exactly ten distinct solutions?
|
|||
|
|
|||
|
|
|||
|
Taking x,y,z of the form a+d,a,a-d respectively,
|
|||
|
the given equation reduces to a*(4d-a)=n.
|
|||
|
Calculating no of solutions for every n till 1 million by fixing a
|
|||
|
,and n must be multiple of a.
|
|||
|
Total no of steps=n*(1/1+1/2+1/3+1/4..+1/n)
|
|||
|
,so roughly O(nlogn) time complexity.
|
|||
|
|
|||
|
"""
|
|||
|
|
|||
|
|
|||
|
def solution(limit: int = 1000000) -> int:
|
|||
|
"""
|
|||
|
returns the values of n less than or equal to the limit
|
|||
|
have exactly ten distinct solutions.
|
|||
|
>>> solution(100)
|
|||
|
0
|
|||
|
>>> solution(10000)
|
|||
|
45
|
|||
|
>>> solution(50050)
|
|||
|
292
|
|||
|
"""
|
|||
|
limit = limit + 1
|
|||
|
frequency = [0] * limit
|
|||
|
for first_term in range(1, limit):
|
|||
|
for n in range(first_term, limit, first_term):
|
|||
|
common_difference = first_term + n / first_term
|
|||
|
if common_difference % 4: # d must be divisble by 4
|
|||
|
continue
|
|||
|
else:
|
|||
|
common_difference /= 4
|
|||
|
if (
|
|||
|
first_term > common_difference
|
|||
|
and first_term < 4 * common_difference
|
|||
|
): # since x,y,z are positive integers
|
|||
|
frequency[n] += 1 # so z>0 and a>d ,also 4d<a
|
|||
|
|
|||
|
count = sum(1 for x in frequency[1:limit] if x == 10)
|
|||
|
|
|||
|
return count
|
|||
|
|
|||
|
|
|||
|
if __name__ == "__main__":
|
|||
|
print(f"{solution() = }")
|