Cod sursa(job #1446892)

Utilizator alexandrustoicaAlexandru Stoica alexandrustoica Data 3 iunie 2015 07:38:18
Problema Ciurul lui Eratosthenes Scor 30
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 vc[MAX];

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

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