2019-10-19 12:02:38 +08:00
|
|
|
# This theorem states that the number of prime factors of n
|
|
|
|
# will be approximately log(log(n)) for most natural numbers n
|
|
|
|
|
|
|
|
import math
|
|
|
|
|
|
|
|
|
2023-10-05 20:39:29 +08:00
|
|
|
def exact_prime_factor_count(n: int) -> int:
|
2019-10-19 12:02:38 +08:00
|
|
|
"""
|
2022-10-13 06:54:20 +08:00
|
|
|
>>> exact_prime_factor_count(51242183)
|
2019-10-19 12:02:38 +08:00
|
|
|
3
|
|
|
|
"""
|
|
|
|
count = 0
|
|
|
|
if n % 2 == 0:
|
|
|
|
count += 1
|
|
|
|
while n % 2 == 0:
|
|
|
|
n = int(n / 2)
|
|
|
|
# the n input value must be odd so that
|
|
|
|
# we can skip one element (ie i += 2)
|
|
|
|
|
|
|
|
i = 3
|
|
|
|
|
|
|
|
while i <= int(math.sqrt(n)):
|
|
|
|
if n % i == 0:
|
|
|
|
count += 1
|
|
|
|
while n % i == 0:
|
|
|
|
n = int(n / i)
|
|
|
|
i = i + 2
|
|
|
|
|
|
|
|
# this condition checks the prime
|
|
|
|
# number n is greater than 2
|
|
|
|
|
|
|
|
if n > 2:
|
|
|
|
count += 1
|
|
|
|
return count
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
n = 51242183
|
2022-10-13 06:54:20 +08:00
|
|
|
print(f"The number of distinct prime factors is/are {exact_prime_factor_count(n)}")
|
2021-09-07 19:37:03 +08:00
|
|
|
print(f"The value of log(log(n)) is {math.log(math.log(n)):.4f}")
|
2019-10-19 12:02:38 +08:00
|
|
|
|
|
|
|
"""
|
|
|
|
The number of distinct prime factors is/are 3
|
|
|
|
The value of log(log(n)) is 2.8765
|
|
|
|
"""
|