小编use*_*880的帖子

找到大于10 ^ 12的素数

1,000,000,000,000和1,000,000,100,000之间的所有素数之和是多少?这很好但很慢.我需要优化它.我是python的新手. 3614000181007876是正确的答案

    A=10 ** 6
N=A+1
B=10 ** 5
prime=[]
sum=0
for i in range(0,N):
    prime.append(0)
for i in range(2,N):
    if(prime[i]==1):
        continue
    for j in range(i*i,N,i):
        prime[j]=1
for i in range((A ** 2)+1,(A ** 2)+B,2):
    for j in range(2,A):
        c=0
        if(prime[j]==1):
            continue
        if(i%j==0):
            c=c+1
            if(c>0):
                break
    if(c==0):
        #print(i)
        sum=sum+i


print(sum)
Run Code Online (Sandbox Code Playgroud)

python algorithm optimization primes

2
推荐指数
1
解决办法
1063
查看次数

标签 统计

algorithm ×1

optimization ×1

primes ×1

python ×1