python - Python 中的快速素数筛选

标签 python algorithm primes sieve-of-eratosthenes

我一直在使用 Eratosthenes 筛法和人们吹捧为相对快速的解决方案(例如 the answers to a question on optimising prime number generation in python 中的一些解决方案)在 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

我的问题是,为什么人们会把相对复杂的食谱中的上述内容吹捧为理想的素数生成器?

最佳答案

我转换了你的代码以适应@unutbu 在Fastest way to list all primes below N 的素筛比较脚本。 如下:

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 [2] + [i*2+1 for i, v in enumerate(sieve) if v and i>0]

在我的 MBPro i7 上,脚本可以快速计算所有小于 1000000 的素数,但实际上比 rwh_primes2、rwh_primes1 (1.2)、rwh_primes (1.19) 和 primeSieveSeq (1.12) 慢 1.5 倍(@andreasbriese 在页尾)。

关于python - Python 中的快速素数筛选,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16004407/

相关文章:

c - 在 C 中显示从 2 到 10,000 的素数

python - Django 1.7 - 为定义添加或更改 related_name 参数

python - 用于添加索引的 SQLAlchemy/Alembic 原始 SQL

python - R和Python的cov和cor的区别

python - python 中集合的元素必须是可变的还是不可变的?

从中序和后序遍历构造二叉树

primes - Project Euler 3 - 为什么这种方法有效?

c++ - 如何检查/查找项目是否在 DEQUE 中

javascript - 隔离嵌套数组中的数组元素,并将其用作 JSON 字段值,并将其兄弟数组元素用作字段值

java - 使用筛子查找小于 LONG 数的素数