【发布时间】:2013-04-06 22:21:24
【问题描述】:
我一直在使用 Eratosthenes 的筛子在 python 中生成素数,人们吹捧为相对较快的选项的解决方案,例如 the answers to a question on optimising prime number generation in python 中的一些解决方案并不简单,我在这里的简单实现在效率上与他们匹敌。下面给出了我的实现
def sieve_for_primes_to(n):
size = n//2
sieve = [1]*size
limit = int(n**0.5)
for i in range(1,limit):
if sieve[i]:
val = 2*i+1
tmp = ((size-1) - i)//val
sieve[i+val::val] = [0]*tmp
return sieve
print [2] + [i*2+1 for i, v in enumerate(sieve_for_primes_to(10000000)) if v and i>0]
定时执行返回
python -m timeit -n10 -s "import euler" "euler.sieve_for_primes_to(1000000)"
10 loops, best of 3: 19.5 msec per loop
虽然上面链接问题的答案中描述的方法是python食谱中最快的方法,但下面给出了
import itertools
def erat2( ):
D = { }
yield 2
for q in itertools.islice(itertools.count(3), 0, None, 2):
p = D.pop(q, None)
if p is None:
D[q*q] = q
yield q
else:
x = p + q
while x in D or not (x&1):
x += p
D[x] = p
def get_primes_erat(n):
return list(itertools.takewhile(lambda p: p<n, erat2()))
运行时会给出
python -m timeit -n10 -s "import euler" "euler.get_primes_erat(1000000)"
10 loops, best of 3: 697 msec per loop
我的问题是,为什么人们从烹饪书中吹捧上述相对复杂的理想素数生成器?
【问题讨论】:
-
谁和在哪里吹捧
erat2“作为理想的主要发电机”?请提供参考资料,以便我们更好地了解您提出问题的背景。 -
您是否将您的算法与
rwh_primes2算法进行了比较? -
erat2仅与该页面上的 OP 代码进行了比较,而 Alex Martelli 仅表示 Cookbook 解决方案的速度是 OP 解决方案的两倍。与rwh_primes2相比,您的解决方案速度要慢两倍。 -
这看起来像是
rwh_primes1的一个小变化。
标签: python algorithm primes sieve-of-eratosthenes