news 2026/6/24 12:25:12

欧拉筛选法求质数的算法解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
欧拉筛选法求质数的算法解析

正常的埃氏筛选法是定义一个bool型的数组,把所有数组的元素初始化为1.表示初始阶段所有数都是质数。开始对数组进行筛选,把所有含有2和2的倍数的所有数筛选掉。在把所有含有3和3的倍数的所有数筛选掉,再把含有5和5的倍数的所有数筛选掉.一直筛选到只剩下素数为止。

#include <bits/stdc++.h> using namespace std; bool f[10001]; // 标记数组,f[i] = true 表示 i 是素数 // 埃氏筛法函数,筛选出 1 到 n 之间的素数 void primer(int n) { memset(f, true, sizeof(f)); // 初始假设所有数都是素数 f[1] = false; // 1 不是素数 int x = sqrt(n); // 只需要筛到 sqrt(n) 即可 for (int i = 2; i <= x; i++) { if (f[i]) { // 如果 i 是素数 // 标记 i 的所有倍数为非素数 for (int j = 2; j <= n / i; j++) { f[i * j] = false; } } } } int main() { int a, b, sum = 0; cin >> a >> b; // 输入区间 [a, b] primer(b); // 筛选出 1 到 b 之间的素数 for (int i = a; i <= b; i++) { if (f[i]) { sum++; // 统计区间内素数个数 } } cout << sum << endl; // 输出结果 return 0; }

其中欧拉筛选法是在埃氏筛选法基础上,让每一个合数,之被他的最小质因数筛选一次。以达到不重复的目的。对于一个合数的分解:将其分解为他的最小质因子与一个其他数的乘积。

欧拉筛法的判断:如果i是质数,那么就将它与之前的质数(包括它本身)的乘积筛掉 。 如果i是合数,那么就将它与从2到它最小的质因子之间的质数的乘积分别筛掉。

#include <bits/stdc++.h> using namespace std; const int MAXN = 1e8 + 5; bool f[MAXN]; // f[i] = true 表示 i 是素数 int a[MAXN]; // 存素数 int sum = 0; // 素数个数 int n; int main() { cin >> n; // 初始化 f 为 true(除了 0 和 1) for (int i = 2; i <= n; i++) f[i] = true; for (int i = 2; i <= n; i++) { if (f[i]) { a[++sum] = i; // 记录素数 } for (int j = 1; j <= sum && i * a[j] <= n; j++) { f[i * a[j]] = false; if (i % a[j] == 0) break; // 保证每个合数只被标记一次 } } cout << sum << endl; return 0; }

对于a[++sum] = i;这行代码的含义是从1开始记录每一个素数的值。不重复

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 13:39:22

15、探索 Red Hat Linux 的实用功能与娱乐体验

探索 Red Hat Linux 的实用功能与娱乐体验 设备同步与实用程序 在进行设备同步时,设备端口可能是 /dev/ttyS0 或 /dev/ttyS1 。不用怕麻烦,通过逐个尝试,就能找到正确的端口。通常情况下,无需担心速度设置,除非你的计算机非常老旧,否则默认值就足够了。以下是同步的…

作者头像 李华
网站建设 2026/6/23 13:41:39

基于Simulink仿真的电动汽车模型构建与参数初始化研究

电动汽车模型Simulink仿真 仿真中搭建了电动汽车模型&#xff0c;包括电池模型、电机模型、动力传输模型以及汽车模型&#xff0c;仿真中的参数由C文件在Matlab中进行初始化设置。咱们今天来唠唠怎么在Simulink里搭电动汽车模型。这玩意儿说复杂吧其实拆开了也就四大块&#xf…

作者头像 李华
网站建设 2026/6/23 13:41:32

JavaScript数组push方法:小白也能懂的入门指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个交互式学习JS push方法的教程应用&#xff1a;1. 分步骤讲解push方法的基本语法&#xff1b;2. 提供可编辑的代码示例&#xff0c;实时显示运行结果&#xff1b;3. 包含5个…

作者头像 李华
网站建设 2026/6/23 15:25:54

IsaacLab机器人仿真系统实战配置指南:从零到专业部署

IsaacLab机器人仿真系统实战配置指南&#xff1a;从零到专业部署 【免费下载链接】IsaacLab Unified framework for robot learning built on NVIDIA Isaac Sim 项目地址: https://gitcode.com/GitHub_Trending/is/IsaacLab 概述 IsaacLab作为基于NVIDIA Isaac Sim构建…

作者头像 李华
网站建设 2026/6/23 15:51:49

WeekToDo终极指南:如何快速搭建免费的周计划待办事项应用

WeekToDo终极指南&#xff1a;如何快速搭建免费的周计划待办事项应用 【免费下载链接】weektodo WeekToDo is a Free and Open Source Minimalist Weekly Planner and To Do list App focused on privacy. Available for Windows, Mac, Linux or online. 项目地址: https://g…

作者头像 李华
网站建设 2026/6/24 6:49:46

25、计算机硬件与Linux文件系统全解析

计算机硬件与Linux文件系统全解析 1. 计算机硬件基础 计算机由多个子系统组成,每个子系统都有特定的功能,它们共同协作构成了我们熟悉的计算机。当涉及网络连接时,网络接口卡(NIC)的品牌和型号是需要了解的信息。接下来,我们重点关注硬盘和内存。 1.1 硬盘控制器 硬盘…

作者头像 李华