c++筛选法求素数

1. 复习---质数(素数)的性质

1. 复习---质数(素数)的性质

定义:质数是指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。

简单判断:根据定义直接模拟判断一个整数N是否为质素如下:

参考程序1

注:数值1比较特殊,既不是质数也不是合数。

优化算法:

上面的程序“时间复杂度”为O(N)---也就是说最坏情况要运行差不多N规模的次。

性质1:合数(大于1的非质数)N一定存在因子d(>1)不超过√N 。

证明:

N是合数,一定有大于1小于N的因子,设为x。

令 y=N/x,显然y也是一个因子,且x*y = N。

显然x和y不可能都超过 √N。

d=min(x,y)即得证。

推理1:如果如果2到√N都不是N的因子,N是质数。

根据推理1,有如下的优化算法:

参考程序2

:sqrt()是平方根函数。如果不想使用这个函数,循环条件“i<=sq”可以改写成“i*i<=N”。

参考程序2的“时间复杂度”为O(sqrt(N) )---也就是说最坏情况要运行差不多N的平方根规模的次。

如果N是10^8规模,参考程序2比参考程序1000多倍!

早期的数学家都喜欢研究质数的分布,现代的信息通讯也经常使用大质数进行加密。怎样快速求N以内的所有质数是一个有意义的问题。

比如100以内的质数有哪些:

图1

显然求N以内的所有质数可以使用前面的参考程序2来判断每个数,看哪些是质数。数学家们的探索永不止步!

性质2:合数N一定存在质数因子d(>1)不超过 √N。

证明:(思考)

推理2:质数的倍数一定不是质数。

根据推理2,数学家运用逆向思维,发明了另一种简便的方法:筛选法---把不超过√N的质数的倍数删除掉,剩下的就是质数。简单讲,对于图1:

1. 1不是质数(特例)

2. 把2的倍数删除

3. 把3的倍数删除

4. 把5的倍数删除

5. 把7的倍数删除

即可。

筛选法求N以内的质数的参考程序。

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浪子小院

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值