Cod sursa(job #1112973)
| Utilizator | Data | 20 februarie 2014 10:51:49 | |
|---|---|---|---|
| Problema | Ciurul lui Eratosthenes | Scor | 10 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.58 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("ciur.in");
ofstream fout("ciur.out");
bool *sieve;
int main()
{
int n, count = 0;
fin>>n;
sieve = new bool[n]();
for(int i = 2; i< n; i++) sieve[i] = 0;
for(int i = 2; i< n; i++)
{
if(sieve[i] != 0) continue;
for(int j = 2; j<= n/i; j++)
{
if(sieve[i*j] == 0){sieve[i*j] = 1; count++;}
}
}
for(int i = 2; i< n; i++) cout<<sieve[i]<<" ";cout<<endl;
fout<<n-2-count<<endl;
return 0;
}
