Cod sursa(job #1017082)

Utilizator PlayLikeNeverB4George Marcus PlayLikeNeverB4 Data 27 octombrie 2013 10:21:05
Problema Ciurul lui Eratosthenes Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include<fstream>
#include<vector>
#include<algorithm>
#include<cmath>

using namespace std;
fstream f("ciur.in");
ofstream g("ciur.out");
int n;


int getPrimes()
{
    n++;
    vector<bool> vec(n);
    fill( vec.begin(), vec.end(), true );
    for(int i=2;i<(double)sqrt((double)n);i++){
        if(vec[i]){
            for(int j=(double)pow((double)i,2.0);j<n;j+=i){
                vec[j]=false;
            }
        }
    }

    int result =0;
    for(int i=2;i<n;i++){
        if(vec[i])
            result++;
    }
    return result;
}

int main()
{
    f>>n;
    g<<getPrimes();

    f.close();
    g.close();

    return 0;
}