news 2026/3/12 14:01:39

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

作者头像

张小明

前端开发工程师

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/3/13 2:44:08

23、Linux常见问题及解决指南

Linux常见问题及解决指南 在使用Linux系统的过程中,我们难免会遇到各种各样的问题。本文将为大家介绍一些常见的Linux问题及相应的解决方法,同时还会分享一些获取Linux信息的途径。 一、获取Linux信息的途径 在解决具体问题之前,我们先了解一下可以从哪些地方获取更多关于…

作者头像 李华
网站建设 2026/3/9 16:43:32

基于SpringBoot的健身服务管理系统计算机毕业设计项目源码文档

项目整体介绍基于 SpringBoot 的健身服务管理系统&#xff0c;直击 “健身房会员管理混乱、课程预约低效、私教排课冲突、运营数据无分析” 的核心痛点&#xff0c;依托 SpringBoot 轻量级框架优势与健身行业场景适配能力&#xff0c;构建 “会员管控 课程运营 私教管理 数据…

作者头像 李华
网站建设 2026/3/12 10:13:56

Min浏览器跨平台终极指南:一键安装与最佳配置完整解析

Min浏览器跨平台体验为用户提供了前所未有的灵活性和便捷性。无论你是Windows、macOS还是Linux用户&#xff0c;这款简约快速的浏览器都能完美适配你的系统需求。在前100字的概要中&#xff0c;我们将带你快速了解Min浏览器跨平台的核心优势。 【免费下载链接】min A fast, min…

作者头像 李华
网站建设 2026/3/5 3:02:02

AI如何自动完成LocalDate与Date的相互转换

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个Java工具类&#xff0c;实现java.time.LocalDate与java.util.Date之间的相互转换。要求包含以下方法&#xff1a;1. LocalDate转Date&#xff08;考虑时区&#xff09; 2. …

作者头像 李华
网站建设 2026/3/4 3:56:38

告别手动配置:WSL自动化安装全攻略

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 设计一个自动化脚本工具&#xff0c;能够一键完成WSL的安装和配置。工具应包含以下功能&#xff1a;1. 自动启用Windows功能&#xff08;如Hyper-V、虚拟机平台&#xff09;&#x…

作者头像 李华
网站建设 2026/3/10 15:40:10

AI音频分离终极指南:从技术原理到实战应用全解析

AI音频分离终极指南&#xff1a;从技术原理到实战应用全解析 【免费下载链接】ultimatevocalremovergui 使用深度神经网络的声音消除器的图形用户界面。 项目地址: https://gitcode.com/GitHub_Trending/ul/ultimatevocalremovergui 在数字音乐制作和音频处理领域&#…

作者头像 李华