当前位置: 首页 > news >正文

质数筛-埃氏筛

质数的定义:只能被 1 和它自身整除的数

优势

相比于暴力的筛法,埃氏筛的算法效率要快不少,虽然比起欧拉筛来说,埃氏筛的优化仍然有待提高。但比起欧拉筛,埃氏筛的理解难度要小不少。

埃氏筛介绍

埃氏筛的时间复杂度在O()

我们可以想到一点,任何数的倍数都不可能为质数,所以我们可以因此来抹去一些与一个数倍数相关的数。其实就是空间换时间的想法

代码部分

暴力筛

#include<iostream> using namespace std; int main(){ int n; cin >> n; //判断 n 是不是质数 int flag = 1; if(n == 1){ flag = 0; }else{ for(int i = 2 ; i < n ; i++){ if(n % i == 0) flag = 0; } } //是质数输出yes,反之输出no if(flag) cout << "yes" << endl; else cout << "no" << endl; return 0; }

当然,在实际的使用中,你也可以通过打表的方法来提高筛法的效率。当然,在算法比赛中,很多时候你打出来的表不一定管用。

循环也可以把遍历的条件改成 i <=, 这样也可以提高效率

埃氏筛

#include<iostream> #include<cstring> using namespace std; const int N = 1e5; int flag[N]; int main(){ int n; cin >> n; //把flag全初始化为 1(除了 0 和 1) memset(flag , 1 ,sizeof(flag)); flag[0] = 0; flag[1] = 0; //开始筛,质数的倍数全都打上标记 for(int i = 2 ; i * i <= n ; i++){ for(int j = i * 2 ; j <= n ; j += i){ flag[j] = 0; } } //输出 for(int i = 0 ; i < n ; i++){ if(flag[i]) cout << i << ' '; } cout << endl; return 0; }
http://www.rkmt.cn/news/129257.html

相关文章:

  • Linly-Talker能否用于博物馆文物解说机器人?
  • Linly-Talker能否用于法院普法宣传教育?
  • 小笔记
  • 手术导航轨迹偏移 补生物力学约束才校准PINN模型
  • Linly-Talker如何防止模型过拟合导致的僵硬表情?
  • [Java]PTA:jmu-Java-06异常-ArrayIntegerStack异常改进版
  • Linly-Talker支持音频降噪预处理吗?提升ASR效果
  • 2025年12月新沂PC砖生产商哪家强? - 2025年品牌推荐榜
  • python django flask餐饮连锁店点餐食材采购管理系统的设计与实现_971i3t7j--论文
  • python django flask高校创新创业课程体系选择系统的设计与实现_学习资源推荐选课系统196muhq--论文
  • Linly-Talker能否接入铁路12306客服系统?
  • 15、Windows管道通信:命名管道与匿名管道详解
  • Linly-Talker能否生成科学家形象讲述前沿科技?
  • 6、Windows 操作系统架构与网络通信详解
  • Ring-flash-2.0:6.1B激活MoE模型推理破百B性能
  • Linly-Talker能否用于监狱服刑人员心理疏导?
  • 计算机毕业设计springboot家乡特色美食推荐系统的设计与实现 SpringBoot驱动的地域风味美食智能推荐平台构建 基于SpringBoot的乡土特色菜品发现与分享系统
  • 7、Windows网络与RPC编程全解析
  • Linly-Talker支持暗黑主题UI界面吗?
  • Linly-Talker在电力巡检机器人中的语音交互应用
  • Linly-Talker如何应对网络波动导致的卡顿问题?
  • Linly-Talker在智慧农业大棚中的语音指导应用
  • Linly-Talker能否生成多个角色切换的剧情视频?
  • Linly-Talker支持多轮对话上下文理解吗?
  • 自动驾驶核心技能:这本Python路径规划书,让算法从“调用”到“掌控”
  • 【期末复习题】-结构类算法题
  • Linly-Talker镜像经过大规模中文语料训练优化
  • 41、PowerShell实用扩展与事件处理
  • Krea Realtime 14B:11fps实时视频大模型
  • GLM-4-9B-0414:小模型大能力,开源新标杆