欧拉筛法与埃氏拉筛

如果我们想知道从零到一个数有哪些质数 ,我们首先会想到运用枚举法 ,将小于这个数的每个数都相乘一遍,这样的做法会大大降低 我们程序的质数增加时间 ,事实上,在我们之前就有许多人尝试运用另外的思维,当然,他们成功了,这就徒手搓出我们现在所使用的几种筛法,而我们现在要讲的正式四种筛法 中的中间两种,欧拉筛埃氏筛

欧拉筛法

步骤:

1.2到某数N之间的自然数列出来,标准格式为:2,3,4,...,N【1】

2.设为第一个素数

3.2的倍数全部剔除

4.到下一个未被剔除的数,将其设为第二个素数;

5.该数的倍数全部剔除

6.复第4、5步,直到所有小于某数的素数都被找出来

【1】:为什么第一个数是2而不是0?//寻找质数从2开始1和0既不是质数也不是合数

图表:

代码实现:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int a[100005]={0},pri[10005];
	int i,j,num;
	num=0;
	for(i=2;i<=100000;i++)
	{
		if(a[i]==0)
		{
			pri[++num]=i;
		}
		for(j=1;j<=num;j++)
		{
			if(i*pri[j]>100000)
			{
				break;
			}
			a[i*pri[j]]=1;
			if(i%pri[j]==0)
			{
				break;
			}
		}
	}
	for(i=1;i<=num;i++)
	{
		cout<<pri[i]<<endl;
	}
	return 0;
}

=========================================================================

埃氏筛法:

步骤:

  1. 2到某数N之间的自然数列出来,标准格式为:2,3,4,...,N

  2. 设第一个数是素数

  3. 枚举所有p的倍数(2p,3p,4p,...),标记为非质数(合数);

  4. 找到下一个 没有标记 且 大于p 的数。如果没有,结束运算;如果有,将该值赋予p,重复步骤4;

  5. 运算结束后,剩下所有未标记的数都是找到的质数。

//我觉得这两个方法大致相同

图表:

图像来源于;(14条消息) 埃拉托色尼筛选法巧解质数问题(埃氏筛法求解素数问题)_质数筛选法动图_吴雨4的博客-CSDN博客

代码实现:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int a[100005]={0};
	int i,j;
	for(i=2;i<=100000/i;i++)
	{
		if(a[i]==0)
		{
			for(j=2;i*j<=100000;j++)
			{
				a[i*j]=1;
			}
		}
	}
	for(i=2;i<=100000;i++)
	{
		if(a[i]==0)
		{
			cout<<i<<endl;
		}
	}
	return 0;
}
相关推荐
2501_933329556 分钟前
媒介宣发技术实践:Infoseek舆情系统的AI中台架构与应用解析
开发语言·人工智能·架构·数据库开发
DuHz1 小时前
论文精读:大语言模型 (Large Language Models, LLM) —— 一项调查
论文阅读·人工智能·深度学习·算法·机器学习·计算机视觉·语言模型
[J] 一坚1 小时前
嵌入式高手C
c语言·开发语言·stm32·单片机·mcu·51单片机·iot
odoo中国1 小时前
Odoo 19技术教程 : 如何在 Odoo 19 中创建 Many2one 组件
开发语言·odoo·odoo19·odoo技术·many2one
加农炮手Jinx1 小时前
LeetCode 72. Edit Distance 题解
算法·leetcode·力扣
借雨醉东风1 小时前
程序分享--常见算法/编程面试题:旋转矩阵
c++·线性代数·算法·面试·职场和发展·矩阵
逻辑驱动的ken1 小时前
Java高频面试考点场景题14
java·开发语言·深度学习·面试·职场和发展·求职招聘·春招
_深海凉_1 小时前
LeetCode热题100-打家劫舍
算法·leetcode·职场和发展
jghhh012 小时前
使用 MATLAB 实现支持向量回归 (SVR) 预测未来数据
算法·matlab
云泽8082 小时前
笔试算法 - 双指针篇(二):四大经典求和题型 + 有效三角形计数问题
c++·算法