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"使用的是百度机翻,不知道对不对