news 2026/1/26 11:53:19

质数筛-欧拉筛

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
质数筛-欧拉筛

对于正常的程序要求,埃氏筛的速度已经是相当不错了,但是在某些极端条件下,埃氏筛的速度可能还不够,这个时候我们就要用到欧拉筛了

思路

埃氏筛存在一个非常严重的缺陷,那就是它会对一个数据进行反复筛选,比如:

6 = 2 * 3

6 = 3 * 2

可以发现,对于 6 这个非质数,我们进行了两次筛选,而对于后面跟大的数来说,可能被筛的次数会更多,这个时候就会对我们筛法的效率产生影响。而欧拉筛法可以避免无效的筛选。

我们发现,对于每个非质数,都会存在唯一的最小质因子

于是我们便可以让每个和数只在它最小质因子与对应因数相乘时才被标记为合数,这样我们就只筛了一次。例如:

6 = 2 * 3 //标记 6

6 = 3 * 2 //已经标记过,便不再标记

核心思想:从第一个质数开始,一个个排除,不做无效的筛选。

人话:从前向后走,边走边乘,乘出来的数就是合数

代码实现

#include<iostream> #include<cstring> using namespace std; const int N = 1e5; int primes[N]; //存储质数 int flag[N]; //标记是质数还是合数,如果是质数为 0 ,开始假设全是质数 int main(){ int n; cin >> n; int pos = 0; for(int i = 2 ; i <= n ; i++){ if(flag[i] == 0){ //如果是质数 primes[pos++] = i; //存储质数 for(int j = 0 ; j < pos && i * primes[j] <= n ; j++){ flag[primes[j] * i] = 1;//标记为合数 } }else{ //如果是合数 for(int j = 0 ; j < pos && primes[j] * i <= n ; j++){ flag[primes[j] * i] = 1;//标记为合数 if(i % primes[j] == 0) break; //如果可以整除说明发现了最小质因子,退出循环 } } } for(int i = 0 ; i < pos ; i++){ cout << primes[i] << ' '; } cout << endl; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/25 2:33:17

手术导航轨迹偏移 补生物力学约束才校准PINN模型

&#x1f4dd; 博客主页&#xff1a;jaxzheng的CSDN主页 目录 医疗数据科学&#xff1a;当Excel表格遇上手术刀 我差点把CT片当成了奶茶订单 数据江湖的三大痛点 数据清洗的血泪史 当AI遇见中医 数据共享的尴尬现场 未来可能的样子 写在最后 医疗数据科学&#xff1a;当Excel表…

作者头像 李华
网站建设 2026/1/26 17:46:44

Linly-Talker如何处理长时间对话的记忆衰减问题?

Linly-Talker如何处理长时间对话的记忆衰减问题&#xff1f; 在虚拟主播流畅推荐商品、AI客服耐心解答复杂问题的表象之下&#xff0c;隐藏着一个长期困扰开发者的核心难题&#xff1a;数字人真的“记得”你之前说过什么吗&#xff1f; 当用户与智能体连续对话超过十几轮后&…

作者头像 李华
网站建设 2026/1/26 23:45:17

Linly-Talker如何应对网络波动导致的卡顿问题?

Linly-Talker如何应对网络波动导致的卡顿问题&#xff1f; 在虚拟主播直播正酣、智能客服全天候待命的今天&#xff0c;一个“卡顿”的数字人可能意味着用户的流失、服务的中断&#xff0c;甚至品牌形象的受损。尽管AI技术已能让数字人“能说会动”&#xff0c;但真正考验其落地…

作者头像 李华
网站建设 2026/1/25 4:43:43

Linly-Talker能否接入高德地图提供出行导航?

Linly-Talker能否接入高德地图提供出行导航&#xff1f; 在智能车载系统日益普及的今天&#xff0c;用户不再满足于“点击起点终点、听语音提示”的传统导航模式。他们更希望有一个能听懂复杂指令、会看路况、还会“皱眉提醒前方拥堵”的虚拟助手——比如一个搭载了大模型的数字…

作者头像 李华
网站建设 2026/1/26 5:33:08

MySQL索引核心:聚集索引与非聚集索引

前言 在学习MySQL过程中&#xff0c;阅读到这样一段话&#xff1a;在 MySQL 中&#xff0c;B 树索引按照存储方式的不同分为聚集索引和非聚集索引。我就在想为什么要分为这两种&#xff0c;下面我就详细介绍这两者的联系、优缺点。 一、聚集索引和非聚集索引的本质 聚集索引…

作者头像 李华
网站建设 2026/1/27 2:37:16

Linly-Talker支持边缘计算部署吗?离线运行可行性分析

Linly-Talker支持边缘计算部署吗&#xff1f;离线运行可行性分析 在智能终端日益普及的今天&#xff0c;人们对数字人系统的期待早已不再局限于“能说话”&#xff0c;而是要求其具备实时响应、隐私安全和稳定可靠的综合能力。尤其是在展厅导览、车载助手、金融柜员等实际场景中…

作者头像 李华