首页 > 技术文章 > P3912 素数个数

Chri-K 2020-09-29 10:44 原文

#include <cstring>
#include <iostream>
using namespace std;
bool isPrime[100000010];
int sum, primes[100000010];
int main()
{
int n;
cin>>n;
memset(isPrime, true, sizeof(isPrime));
sum = 0;
for (int i = 2; i <= n; ++ i)
{
if (isPrime[i])
{
primes[sum ++] = i;
}
for (int j = 0; j < sum && i * primes[j] <= n; ++ j)
{
isPrime[i * primes[j]] = false;
if (i % primes[j] == 0)
{
break;
}
}
}
cout<<sum<<endl;
return 0;
}

推荐阅读