Cod sursa(job #2751813)
| Utilizator | Data | 15 mai 2021 21:07:19 | |
|---|---|---|---|
| Problema | Ciurul lui Eratosthenes | Scor | 0 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.6 kb |
#include <fstream>
using namespace std;
ifstream in("ciur.in");
ofstream out("ciur.out");
const int N=2000000;
bitset <N+1> ciur;///ciur[i]=0 inseamna ca nu este marcat, pe cand ciur[i]=1 inseamna ca e marcat
int main()
{
int n,i,cnt=1,j;
in>>n;
ciur[0]=ciur[1]=1;
for(j=4; j<=n; j+=2)
ciur[j]=1;
for(i=3; i*i<=n; i+=2)
if(ciur[i]==0)///verificare de numar prim
{
cnt++;
for(j=i*i; j<=n; j+=2*i)
ciur[j]=1;
}
for(;i<=n;i+=2)
if(ciur[i]==0)
cnt++;
out<<cnt;
return 0;
}
