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

朴素筛法

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

枚举所有小于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)一个级别
相关推荐
代码中介商15 小时前
图论入门:从基础到遍历算法
数据结构·算法·图论
小满Autumn15 小时前
WPF 依赖属性速查手册
笔记·c#·wpf·上位机·mvvm
枕星而眠15 小时前
Linux IO多路复用:select、poll、epoll 核心原理与进阶实战
linux·运维·服务器·c++·后端
csdn_aspnet15 小时前
Python 霍尔分区算法(Hoare‘s Partition Algorithm)
开发语言·python·算法
8Qi815 小时前
LeetCode 295:数据流的中位数(Median Finder)—— Java 题解 ✅
java·算法·leetcode·优先队列··中位数
jjjlike15 小时前
三款主流AI编程工具实测对比:以C++自研UI引擎项目为测评基准
c++·ai编程
程序喵大人15 小时前
C++与C语言的核心区别是啥
c语言·开发语言·c++
学计算机的计算基15 小时前
MySQL 锁体系全解:从 MDL 到间隙锁,一次讲透
java·数据库·笔记·python·mysql
Engineer邓祥浩15 小时前
宏观认知(4):AI与社会——吴恩达《AI for Everyone》Week4学习笔记
人工智能·笔记·学习
Trouvaille ~15 小时前
【Redis篇】Redis 事务:原子性与脚本执行机制
数据库·redis·后端·算法·junit·lua·原子性