Cod sursa(job #1732230)
Utilizator | Data | 21 iulie 2016 10:43:39 | |
---|---|---|---|
Problema | Ciurul lui Eratosthenes | Scor | 30 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.45 kb |
#include <iostream>
#include <fstream>
#include <vector>
using namespace std;
ifstream f ("ciur.in");
ofstream t ("ciur.out");
int n;
bool v[2000010];
void sift(int x)
{
for (int i=x*x; i<=n; i+=x)
v[i]=true;
}
int magic()
{
int s=0;
for (int i=2; i<=n; ++i)
{
if (!v[i])
++s;
sift(i);
}
return s;
}
int main()
{
f>>n;
t<<magic();
return 0;
}