[笔记] 筛素数——朴素筛法及其优化:埃氏筛法 #质数(素数)

编程入门 行业动态 更新时间:2024-10-24 04:30:34

[笔记] 筛<a href=https://www.elefans.com/category/jswz/34/1764940.html style=素数——朴素筛法及其优化:埃氏筛法 #质数(素数)"/>

[笔记] 筛素数——朴素筛法及其优化:埃氏筛法 #质数(素数)

朴素筛法

从2~n枚举 i,再从小到大枚举所有已知的质数 primes[j],筛掉合数 i*primes[j],遇到新的质数就入队==
枚举所有小于n的数i,将i的所有倍数筛掉
筛完后剩下的数就是质数

朴素做法
void get_primes(int n ){for(int i = 2; i <= n; i ++){if(!st[i])primes[cnt ++] = i;//如果是质数,入队for(int j = i + i; j <= n; j +=i)st[j] = 1;//删掉它的所有倍数}
}
时间分析:n/2 + n/3 +....+n/n = n log n(大概)

埃氏筛法

  1. 朴素做法的优化:埃氏筛法。(此算法由一个埃及人发明,所以叫 埃氏筛法)
    原理:当i不是质数时,没必要筛掉它的倍数,因为它的吧倍数将会是其它质数的倍数。
  2. 筛到N时,如果N没有被筛掉,就说在2~i-1中没有N的约数,所以N是质数。
    时间是O(n log n)约等于 O(n)(和O(n)一个级别)
    3.补充:质数定理:1~n当中有 n / logn 个质数
埃氏筛法
void get_primes(int n ){for(int i = 2; i <= n; i ++){if(!st[i]) {primes[cnt ++] = n;//没被筛掉,说明是质数for(int j = i + i; j <= n; j += i)//干掉它的所有倍数st[j] = 1;}	}
}
时间是O(n log log n)和O(n)一个级别

更多推荐

[笔记] 筛素数——朴素筛法及其优化:埃氏筛法 #质数(素数)

本文发布于:2023-12-06 03:46:48,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1666345.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:素数   质数   朴素   笔记   埃氏筛法

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!