news 2026/6/10 2:28:31

算法学习——素数筛法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法学习——素数筛法

素数:一个大于1的自然数,除了1和它本身以外不再有其他因数的数称为素数。

合数:一个大于1的自然数,除了1和它本身以外还有其他因数的数称为合数。

因数:整数a除以整数b(b≠0)的商正好是整数而没有余数,称b是a的因数。

一、试除法

一次次试看能不能被因子整除。

int is_prime(int n) { //这里用i<=n/i,防止溢出,如i=1e6 for (int i = 2;i <= n / i;i++) { if (n % i == 0) return 0; } return 1; }

二、埃式筛法——接近线性O(logN)

素数的倍数一定是合数。找出合数,剩下都是素数。

#include<iostream> #include<vector> using namespace std; const int n = 1e6 + 10; //创建一个bool数组来标记素数 //初始时假设所有数都是素数 vector <bool> isPrime(n + 1, true); int main() { //遍历2~sqrt(n)的所有数 for (int p = 2;p <= n / p;p++) { //如果p是素数 if (isPrime[p]) { //标记p所有的倍数为非素数 for (int i = p * p;i <= n;i += p) isPrime[i] = false; } } return 0; }

三、欧拉筛法——线性

埃式筛有一些重复标记,欧拉筛去除了这些标记。

整数唯一分解定理:任何大于1的正整数n都可以唯一分解为有限个质数的乘积,任何合数都有他对应的一个最小质因子。只通过这个最小质因子将其标记,这样就避免了重复标记。

每个数都只被它的最小质因数筛去。

#include<iostream> #include<bitset> using namespace std; const int maxn = 1e6 + 10; bitset<maxn> pri;//0为素数,1为合数 int primes[maxn]; int pp = 0; int main() { int N = 1e6; int cnt = 0; for (int i = 2;i <= N;i++) { if (!pri[i]) { primes[pp] = i; pp++; } for (int j = i;j <= pp;j++) { pri[primes[j] * i] = 1; if (i % primes[j] == 0) break; } } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 0:44:25

SIR-3000地质雷达信号弱处理方法

SIR-3000作为雷达探测仪器&#xff0c;信号强弱直接影响数据采集精度&#xff0c;其信号弱问题主要源于连接、参数设置、环境干扰或硬件异常&#xff0c;可按以下步骤逐步排查处理&#xff0c;优先操作简单易上手的项&#xff0c;再推进至专业调试&#xff0c;确保高效解决问题…

作者头像 李华
网站建设 2026/6/10 1:22:32

数据科学和临床数据科学的发展

下面内容摘录自《用R探索医药数据科学》专栏文章的部分内容&#xff08;原文7310字&#xff09;。 1篇1章1节&#xff1a;医药数据科学的历程和发展&#xff0c;用R语言探索数据科学&#xff08;更新20241029&#xff09;_《用r探索医药数据科学》-CSDN博客 一、数据科学和临床…

作者头像 李华
网站建设 2026/6/5 20:26:35

开始开发网络版的APP

主要目的是&#xff1a;复习Django&#xff0c;因为不复习一下&#xff0c;就全都忘记了。作为app后端&#xff0c;当然要做到熟练。我们的服务器既然在国外&#xff0c;那就不用担心什么许可证的问题。还可以先上架一些有用的服务&#xff1a;比如在线文件格式转换什么的。

作者头像 李华
网站建设 2026/6/5 13:20:56

还没部署OpenClaw?2026年OpenClaw(Clawdbot)秒级部署图文步骤

还没部署OpenClaw&#xff1f;2026年OpenClaw(Clawdbot)秒级部署图文步骤&#xff01;OpenClaw(原名Clawdbot/Moltbot)是一款开源的本地优先AI代理与自动化平台。它不仅能像聊天机器人一样对话&#xff0c;更能通过自然语言调用浏览器、文件系统、邮件等工具&#xff0c;完成整…

作者头像 李华