写个小程序查看500以内的质数

Posted caizhw3

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了写个小程序查看500以内的质数相关的知识,希望对你有一定的参考价值。

‘‘‘
写一个500以内的Eratosthenes筛法找出全部素数
‘‘‘
class node(object):
    def __init__(self,num):
        self.visited = False
        self.isPrime = False
        self.num = num
matrix = [node(i+1) for i in range(500)]
count = 0
def isPrime(num):
    for i in range(2,int(num**0.5)+1):
        if(num % i == 0):
            return False
    return True

def change_sucessors(num):
    for i in range(num+1,len(matrix)):
        if((i+1) % num == 0):
            matrix[i].visited = True
            matrix[i].isPrime = False

def Eratosthenes(start,end):
    global count
    for i in range(start,end):
        if(matrix[i].visited ==False):
            matrix[i].visited = True
            if(isPrime(matrix[i].num)==True):
                count += 1
                matrix[i].isPrime = True
                change_sucessors(matrix[i].num)
def show():
    for i in range(len(matrix)):
        if(matrix[i].isPrime == True):
            print(str(matrix[i].num)+,,end=‘‘)
    print(
the num of all is +str(count))

def main():
    Eratosthenes(1,500)
    show()
main()

结果如图

技术分享图片

 

以上是关于写个小程序查看500以内的质数的主要内容,如果未能解决你的问题,请参考以下文章

没有基础也能写个小程序

没有基础也能写个小程序

N - 寿司晚宴 HYSBZ - 4197 状压dp

编写程序求2到100以内所有质数,下面一个程序中当i=2时,从第二个for循环给我分析一下执行的过程,详细的!

计算n以内质数的个数

写个小程序从FTP上下载文件