Python 素数算法

Python algorithm for prime numbers

我正在尝试过滤掉 1 到 100 之间的素数,这是代码。但是,结果发现输出中遗漏了很多数字。

def isnot_prime(x):
if x == 1:
    return True
if x == 2:
    return False
for i in range(2, int(x**0.5)+1):
    if x % i == 0:
        return True
    else:
        return False

print filter(isnot_prime, range(1,101))

输出为[1, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42 , 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 66, 68, 70, 72, 74, 76, 78, 80, 82, 84, 86, 88, 90, 92 , 94, 96, 98, 100].

一定是算法有问题。我该如何改进它?

谢谢。

将您的 for 修改为:

for i in range(2, int(round(x**0.5 + 1))+1):
    if x % i == 0:
        return True

删除 else: 并记住 int(float) 只取整数部分(它不舍入)。

此外,请记住,有更快的算法可以执行此操作。例如 Sieve of Eratosthenes 是一种快速而简单的算法。

我会这样做:

print filter(lambda x: len(['' for y in range(2,x) if x%y==0])==0,range(1,101) )