我在这里写的筛算法遇到了问题。我已经尝试修复它总共大约 10 个小时。我在这里四处寻找类似的问题,但似乎找不到遇到此问题的人。我对 python 比较陌生,在阅读了很多生成器文档之后,我设法编写了可以工作的代码。但是,我仍然不知道为什么我的第一次尝试失败了。
我想出的只是在每个连续的筛分步骤中似乎 gen1 实际上并没有被清空。因此,我尝试在名称 gen1 和 gen2 之间交替,删除每个名称以避免此问题。那也没有用。
我真的很感激对此的一些见解,以及任何改进我现在所拥有的建议。
这是失败的代码:
def primes(n):
"yields primes up to n. For use with large n"
q = 0
yield 2
gen1 = (x for x in range(3,n,2))
while q*q < n:
q = next(gen1)
gen1 = (x for x in gen1 if x%q != 0)
yield q
else:
while 1:
try:
yield next(gen1)
except:
StopIteration
break
这是我当前的代码:
import math
global gen1
global gen
def gen1(x):
for i in range(3,x,2):
yield i
def gen(generator,n):
"Input generator and current starting 'index' for the generator"
# Recursively defines new generator for sieve of Eratosthenes
for i in range(n+1):
predicate = next(generator)
yield predicate
for i in generator:
if i % predicate != 0:
yield i
def primes(n):
yield 2
a = gen1(n)
for i in range(math.ceil(math.sqrt(n))):
a = gen(a,i)
yield from a