mirror of
https://github.com/TheAlgorithms/Python.git
synced 2024-12-18 17:20:16 +00:00
07e991d553
* ci(pre-commit): Add pep8-naming to `pre-commit` hooks (#7038) * refactor: Fix naming conventions (#7038) * Update arithmetic_analysis/lu_decomposition.py Co-authored-by: Christian Clauss <cclauss@me.com> * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * refactor(lu_decomposition): Replace `NDArray` with `ArrayLike` (#7038) * chore: Fix naming conventions in doctests (#7038) * fix: Temporarily disable project euler problem 104 (#7069) * chore: Fix naming conventions in doctests (#7038) Co-authored-by: Christian Clauss <cclauss@me.com> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
63 lines
1.2 KiB
Python
63 lines
1.2 KiB
Python
"""
|
|
Highly divisible triangular numbers
|
|
Problem 12
|
|
The sequence of triangle numbers is generated by adding the natural numbers. So
|
|
the 7th triangle number would be 1 + 2 + 3 + 4 + 5 + 6 + 7 = 28. The first ten
|
|
terms would be:
|
|
|
|
1, 3, 6, 10, 15, 21, 28, 36, 45, 55, ...
|
|
|
|
Let us list the factors of the first seven triangle numbers:
|
|
|
|
1: 1
|
|
3: 1,3
|
|
6: 1,2,3,6
|
|
10: 1,2,5,10
|
|
15: 1,3,5,15
|
|
21: 1,3,7,21
|
|
28: 1,2,4,7,14,28
|
|
We can see that 28 is the first triangle number to have over five divisors.
|
|
|
|
What is the value of the first triangle number to have over five hundred
|
|
divisors?
|
|
"""
|
|
|
|
|
|
def count_divisors(n):
|
|
n_divisors = 1
|
|
i = 2
|
|
while i * i <= n:
|
|
multiplicity = 0
|
|
while n % i == 0:
|
|
n //= i
|
|
multiplicity += 1
|
|
n_divisors *= multiplicity + 1
|
|
i += 1
|
|
if n > 1:
|
|
n_divisors *= 2
|
|
return n_divisors
|
|
|
|
|
|
def solution():
|
|
"""Returns the value of the first triangle number to have over five hundred
|
|
divisors.
|
|
|
|
>>> solution()
|
|
76576500
|
|
"""
|
|
t_num = 1
|
|
i = 1
|
|
|
|
while True:
|
|
i += 1
|
|
t_num += i
|
|
|
|
if count_divisors(t_num) > 500:
|
|
break
|
|
|
|
return t_num
|
|
|
|
|
|
if __name__ == "__main__":
|
|
print(solution())
|