Cod sursa(job #1446891)

Utilizator alexandrustoicaAlexandru Stoica alexandrustoica Data 3 iunie 2015 07:36:31
Problema Ciurul lui Eratosthenes Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.58 kb
#include <iostream>
#include <fstream>
#include <cstring>
#include <iomanip>
#include <algorithm>
using namespace std;

ifstream fin("ciur.in");
ofstream fout("ciur.out");

const long long MAX = 2000000;
long long numar;
int vector[MAX];

void mark(int vector[], long long numar)
{
	for(int i = 2; i*i <= numar; i++)
	{
		if(vector[i] == 0)
		for(int j = i*i; j <= numar; j=j+i)
			vector[j] = 1;
	}
}

int main()
{
	fin >> numar;
	mark(vector, numar);
	long long sum = 0;
	for(long long i = 2; i <= numar; i++)
		if(vector[i] == 0) sum++;
	fout << sum;
	return 0;
}