Cod sursa(job #1322120)
| Utilizator | Data | 19 ianuarie 2015 19:43:49 | |
|---|---|---|---|
| Problema | Ciurul lui Eratosthenes | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.46 kb |
#include<stdio.h>
#include<bitset>
#include<algorithm>
#include<math.h>
using namespace std;
#define nmax 2000010
int n,t;
bitset<nmax> v;
int main()
{
freopen("ciur.in","r",stdin);
freopen("ciur.out","w",stdout);
scanf("%d",&n);
for(int i=2;i<=sqrt(n);++i)
{
if(v[i]==0)
{
for(int j=i*i;j<=n;j+=i)
v[j]=1;
}
}
for(int i=2;i<=n;++i) if(v[i]==0) t++;
printf("%d",t);
}
