Cod sursa(job #3182173)
Utilizator | TeodorV TeodorV | Data | 8 decembrie 2023 18:29:57 |
---|---|---|---|
Problema | Ciurul lui Eratosthenes | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.57 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream fin("ciur.in");
ofstream fout("ciur.out");
const int Nmax=2000001;
bitset<Nmax> ciur;
void initciur()
{
ciur[0]=ciur[1]=1;
for(int i=4; i<Nmax; i+=2)
ciur[i]=1;
for(int i=3; i*i<Nmax; i+=2)
{
if(ciur[0]==1)
{
for(int j=i*i; j<Nmax; j+=i)
ciur[j]=1;
}
}
}
int main()
{
initciur();
int n;
fin>>n;
int cnt=0;
for(int i=2; i<=n; i++)
cnt+=(!ciur[i]);
fout<<cnt;
return 0;
}