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

朴素筛法

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

枚举所有小于n的数i,将i的所有倍数筛掉

筛完后剩下的数就是质数

cpp 复制代码
朴素做法
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 个质数
cpp 复制代码
埃氏筛法
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)一个级别
相关推荐
爱听歌的周童鞋2 分钟前
Learn-Claude-Code | 笔记 | Collaboration | s11 Autonomous Agents
笔记·llm·agent·claude code·collaboration·autonomous
Hello eveybody14 分钟前
介绍一下背包DP(C++)
开发语言·c++·动态规划·dp·背包dp
代码中介商21 分钟前
C语言链表完全指南:从单节点到链表管理
c语言·算法·链表
05候补工程师23 分钟前
[线性代数] 判定线性相关性的“降维打击”:从基本定理到速通特殊法
经验分享·笔记·学习·线性代数·考研
charlie11451419128 分钟前
AwesomeQt:最小的Qt6系列迷你版本教程发布!
linux·c++·qt·c
小小de风呀1 小时前
de风——【从零开始学C++】(四):类和对象(下)
开发语言·c++·算法
CSCN新手听安1 小时前
【Qt】系统相关(一)内容简介,事件概念,事件的处理
开发语言·c++·qt
不想写代码的星星1 小时前
重识 std::tuple:一个被低估的编译期异构容器
开发语言·c++
aqiu1111111 小时前
[特殊字符]【算法日记 14】数论入门神题:最大公约数与最小公倍数的“乘积守恒定律”
算法
sweetheart7-71 小时前
go/golang 入门学习笔记(Java/Python/C++转Go快速上手)
笔记·学习·golang·go语言