我对Python相对较新,对于两个相对简单的代码块的性能感到困惑。第一个函数给定一个素数列表,生成一个数字n的质因数分解。第二个生成数字n的所有因子的列表。我本以为prime_factor
(对于相同的n)会比factors
快,但事实并非如此。我不是在寻找更好的算法,而是想了解为什么prime_factor
比factors
慢这么多。
def prime_factor(n, primes):
prime_factors = []
i = 0
while n != 1:
if n % primes[i] == 0:
factor = primes[i]
prime_factors.append(factor)
n = n // factor
else: i += 1
return prime_factors
import math
def factors(n):
if n == 0: return []
factors = {1, n}
for i in range(2, math.floor(n ** (1/2)) + 1):
if n % i == 0:
factors.add(i)
factors.add(n // i)
return list(factors)
使用 timeit
模块,
{ i:factors(i) for i in range(1, 10000) }
需要 2.5 秒
{ i:prime_factor(i, primes) for i in range(1, 10000) }
需要 17 秒
这对我来说很惊讶。 factors
检查从 1 到 sqrt(n) 的每个数字,而 prime_factor
只检查质数。 我希望能获得任何有助于理解这两个函数性能特征的帮助。
谢谢
编辑:(响应 roliu)
以下是我生成从 2 到 up_to
的质数列表的代码:
def primes_up_to(up_to):
marked = [0] * up_to
value = 3
s = 2
primes = [2]
while value < up_to:
if marked[value] == 0:
primes.append(value)
i = value
while i < up_to:
marked[i] = 1
i += value
value += 2
return primes
prime_factors()
函数的primes
参数? - rliu