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

朴素筛法

从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)一个级别
相关推荐
laplace01237 分钟前
Part 3:模型调用、记忆管理与工具调用流程(LangChain 1.0)笔记(Markdown)
开发语言·人工智能·笔记·python·langchain·prompt
only-qi17 分钟前
leetcode2. 两数相加
算法·leetcode
鲨莎分不晴18 分钟前
拯救暗淡图像:深度解析直方图均衡化(原理、公式与计算)
人工智能·算法·机器学习
wdfk_prog32 分钟前
[Linux]学习笔记系列 -- [fs]open
linux·笔记·学习
wdfk_prog33 分钟前
[Linux]学习笔记系列 -- [fs]nsfs
linux·笔记·学习
手揽回忆怎么睡34 分钟前
Streamlit学习笔记2
笔记·学习
DuHz36 分钟前
242-267 GHz双基地超外差雷达系统:面向精密太赫兹传感与成像的65nm CMOS实现——论文阅读
论文阅读·物联网·算法·信息与通信·毫米波雷达
AI科技星1 小时前
时空的固有脉动:波动方程 ∇²L = (1/c²) ∂²L/∂t² 的第一性原理推导、诠释与验证
数据结构·人工智能·算法·机器学习·重构
阿豪只会阿巴1 小时前
【多喝热水系列】从零开始的ROS2之旅——Day4
c++·笔记·python·ros2
charlie1145141912 小时前
FreeRTOS:软件定时器(Software Timers)与时间管理
开发语言·笔记·学习·freertos·实时操作系统·工程