欧拉筛:
欧拉筛为求质数最快的方法,O(n)的复杂度,每个数只会被筛一次。
上代码:
#include <bits/stdc++.h>
using namespace std;
const int N = 100010;
int cnt;//2到n中有多少个质数
int primes[N];//将2到n中的质数存到prmes数组里面
bool st[N];//st[i]表示数字i是否被筛过,true表示被筛过,也就不是质数
void get_primes(int n)//欧拉筛
{
for (int i = 2; i <= n; i++)
{
if (!st[i])primes[cnt++] = i;
for (int j = 0; primes[j] * i <= n; j++)
{
st[primes[j] * i] = true;
if (i % primes[j] == 0)break;
}
}
}
int main()
{
int n;
cin >> n;
get_primes(n);
cout << cnt;
return 0;
}