Cod sursa(job #2467530)
Utilizator | Data | 4 octombrie 2019 16:23:48 | |
---|---|---|---|
Problema | Ciurul lui Eratosthenes | Scor | 10 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.38 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream in ("ciur.in");
ofstream out ("ciur.out");
bool prim[2000000];
int main()
{ int i, n, cnt=0, j;
prim[0]=prim[1]=1;
in>>n;
for(i=2; i*i<=n; i++)
prim[i]=1;
for(i=2; i*i<=n; i++)
if(prim[i]==1)
{
for(j=2; j<=n; j=j+i)
prim[i*j]=1;
}
for(i=1;i<=n;++i)
if(prim[i]==0)
cnt++;
out<<cnt;
return 0;
}