C++算法——埃氏筛

C++判断素数:埃氏筛

思路

这个算法是利用打表的方法来计算的:
首先,我们要知道一个特性
就是一个质数的倍数,一定是一个合数

利用这个特性
我们可以写出以下代码

for (int i = 2; i * i <= n; i++)
{
	if (!prime[i] == true)
	{
		for (int j = i + i; j <= n; j++)
		{
			prime[j] = true;//这个数就是质数的倍数
		}
	}
}

这段代码就是埃氏筛的核心代码(就这些)
上面的判断是为了以防重复打表,下面的for是为了标记这个质数所有小于n的合数

代码

#include <bits/stdc++.h>
using namespace std;
const int MAXN = 1E9 + 7;

bool prime_n[MAXN];

int EhrlichSieve(bool prime[], int n)
{
	for (int i = 2; i * i <= n; i++)
	{
		if (!prime[i] == true)
		{
			for (int j = i + i; j <= n; j++)
			{
				prime[j] = true;
			}
		}
	}
	return 0;
}
int main()
{
	EhrlichSieve(prime_n, 1000000);
	int q;
	cin >> q;
	while (q--)
	{
		int x;
		cin >> x;
		if (prime_n[x] == false)
		{
			cout << x << "是素数\n";
		}
		else
		{
			cout << x << "不是素数\n";
		}
	}
	return 0;
}
//这里的"EhrlichSieve"使用的是百度机翻,不知道对不对

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-06-12 10:58:06       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-12 10:58:06       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-12 10:58:06       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-12 10:58:06       20 阅读

热门阅读

  1. 安全通告:NGINX HTTP/3 QUIC 漏洞

    2024-06-12 10:58:06       8 阅读
  2. 切换到root用户的方法和区别

    2024-06-12 10:58:06       9 阅读
  3. Git最全管理详解

    2024-06-12 10:58:06       8 阅读
  4. STM32 UART 错误代码 HAL_UART_ERROR_PE

    2024-06-12 10:58:06       8 阅读
  5. 实现EM算法的主循环

    2024-06-12 10:58:06       8 阅读
  6. go语言接口之http.Handler接口

    2024-06-12 10:58:06       9 阅读
  7. 富格林:活用经验可信提高出金

    2024-06-12 10:58:06       7 阅读
  8. 力扣1146.快照数组

    2024-06-12 10:58:06       11 阅读
  9. C++中的享元模式

    2024-06-12 10:58:06       9 阅读