python求质数

  1. 质数:又称素数,乘法因子只有1和它自身的自然数;显然,素数肯定是奇数(除去2),而奇数却不一定是素数。如:9是奇数,但是它还有3这个乘法因子。
  2. 那么如何判断一个数是否为质数呢?
    先从乘法因子讨论,一个自然数的最小乘法因子必然是一组质数,对吧,比如15,它的乘法因子有3,5(从数学角度上,1也是,但是对于程序没有影响,暂不讨论),而3和5都是质数。
    也就是说,一个数如果是质数的话,它必然不能被2、3、5、7整除,这样就很容易判断一个数是否为质数了。

编程环境:
centos 7
python 3.6.6

这里求的是100万以内的质数
n=4
print(2,3,5,7)
for i in range(2,10**6):
    if i%2!=0:
        if i%3!=0:
            if i%5!=0:
                if i%7!=0:
                    n+=1
                    print('%d,'%i)
print('the number is %d'%n)

结果:共有228574个质数
代码的一些解释;

  1. n=4;是因为2、3、5、7这四个质数,循环中运行的结果不含这几个数,应另外加上。
  2. 在python3中i%2表示求余
  3. python中“**”表示幂运算
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值