mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
Reduced Time Complexity to O(sqrt(n)) (#7429)
* Reduced Time Complexity to O(sqrt(n)) * Added testmod * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
This commit is contained in:
parent
b092f9979f
commit
a3383ce3fd
@ -1,3 +1,7 @@
|
||||
from doctest import testmod
|
||||
from math import sqrt
|
||||
|
||||
|
||||
def factors_of_a_number(num: int) -> list:
|
||||
"""
|
||||
>>> factors_of_a_number(1)
|
||||
@ -9,10 +13,22 @@ def factors_of_a_number(num: int) -> list:
|
||||
>>> factors_of_a_number(-24)
|
||||
[]
|
||||
"""
|
||||
return [i for i in range(1, num + 1) if num % i == 0]
|
||||
facs: list[int] = []
|
||||
if num < 1:
|
||||
return facs
|
||||
facs.append(1)
|
||||
if num == 1:
|
||||
return facs
|
||||
facs.append(num)
|
||||
for i in range(2, int(sqrt(num)) + 1):
|
||||
if num % i == 0: # If i is a factor of num
|
||||
facs.append(i)
|
||||
d = num // i # num//i is the other factor of num
|
||||
if d != i: # If d and i are distinct
|
||||
facs.append(d) # we have found another factor
|
||||
facs.sort()
|
||||
return facs
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
num = int(input("Enter a number to find its factors: "))
|
||||
factors = factors_of_a_number(num)
|
||||
print(f"{num} has {len(factors)} factors: {', '.join(str(f) for f in factors)}")
|
||||
testmod(name="factors_of_a_number", verbose=True)
|
||||
|
Loading…
Reference in New Issue
Block a user