mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
895dffb412
* [pre-commit.ci] pre-commit autoupdate updates: - [github.com/astral-sh/ruff-pre-commit: v0.0.291 → v0.0.292](https://github.com/astral-sh/ruff-pre-commit/compare/v0.0.291...v0.0.292) - [github.com/codespell-project/codespell: v2.2.5 → v2.2.6](https://github.com/codespell-project/codespell/compare/v2.2.5...v2.2.6) - [github.com/tox-dev/pyproject-fmt: 1.1.0 → 1.2.0](https://github.com/tox-dev/pyproject-fmt/compare/1.1.0...1.2.0) * updating DIRECTORY.md * Fix typos in test_min_spanning_tree_prim.py * Fix typos * codespell --ignore-words-list=manuel --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: github-actions <${GITHUB_ACTOR}@users.noreply.github.com> Co-authored-by: Tianyi Zheng <tianyizheng02@gmail.com> Co-authored-by: Christian Clauss <cclauss@me.com>
56 lines
1.8 KiB
Python
56 lines
1.8 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 a
|
||
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 divisible 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, a > d and 4d < a
|
||
|
||
count = sum(1 for x in frequency[1:limit] if x == 10)
|
||
|
||
return count
|
||
|
||
|
||
if __name__ == "__main__":
|
||
print(f"{solution() = }")
|