筛质数汇总

埃式筛法

1、从小到大枚举每个数。

2、若当前数没被划掉,必定是质数,记录该质数。

3、枚举当前质数的倍数,必定是合数,划掉合数。

时间复杂度O(nloglogn)

代码:

cpp 复制代码
//埃式筛法
int vis[N];  //真为合数
int prim[N];  //记录质数
int cnt;  //质数个数

void aishi(int n){
    for(int i=2;i<=n;i++){
        if(!vis[i]){
            prim[++cnt]=i;
            for(int j=i*i;j<=n;j+=i){
                vis[j]=1;
            }
        }
    }
}

欧拉筛法(线性筛法)

从小到大枚举每个数

1、若当前数没被划掉,必定是质数,记录该质数。

2、枚举已记录的质数(如果合数已越界则中断)

(1)合数未越界,则划掉合数。

(2)条件i%p==0,保证合数只被最小质因子划掉:

若i是质数,则最多枚举到自身中断。

若i是合数,则最多枚举到自身的最小质数中断。

时间复杂度O(n)

代码:

cpp 复制代码
//欧拉筛法
bool vis[N*100];  //真为合数
int prime[N*10];  //记录质数
int cnt;  //质数个数

void oula(int n){
    cnt=0;
    for(int i=2;i<=n;i++){
        if(!vis[i]){
            prime[++cnt]=i;
        }
        for(int j=1;i*prime[j]<=n;j++){
            vis[i*prime[j]]=1;
            if(i%prime[j]==0) break;
        }
    }
}
相关推荐
不知名的老吴1 分钟前
机器学习评价之基础指标
人工智能·算法·机器学习
Felven1 分钟前
D. Divisible Pairs
算法
源代码杀手2 分钟前
基于ROS2+Gazebo+RIVE的40项计算机视觉前沿机器人项目(含视觉算法原理与源码获取方式)
算法·计算机视觉·机器人
MrZhao4003 分钟前
大模型量化到底在做什么:从浮点数表示到 Qwen FP8 实践
算法
JieE2124 分钟前
LeetCode35. 搜索插入位置:二分查找的基础与细节
javascript·算法
8Qi810 分钟前
LeetCode 188 & 123:股票买卖问题(限制交易次数)—— 联合题解
算法·leetcode·职场和发展·动态规划
KaMeidebaby14 分钟前
卡梅德生物技术快报|细胞周期检测抗原流式分析:参数调试、软件拟合与问题排查
网络·人工智能·python·网络协议·tcp/ip·算法·机器学习
一只齐刘海的猫18 分钟前
【Leetcode】三数之和
数据结构·算法·leetcode
lightqjx19 分钟前
【算法】数据结构_扩展域并查集
数据结构·算法·并查集·扩展域并查集
San813_LDD21 分钟前
[量化]《多线程数据同步精讲:std::mutex 的底层原理与最佳实践》
c语言·数据结构