Cod sursa(job #677505)

Utilizator Catah15Catalin Haidau Catah15 Data 10 februarie 2012 12:05:11
Problema Ciurul lui Eratosthenes Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.53 kb
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string>

using namespace std;

#define maxN 2000010

bool cont[maxN];
int k;


void ciur (int X)
{
	if (X < 2) return;
	k = 1;
	
	for (int i = 3; i <= X; i += 2)
	{
		if (cont[i]) continue;
		
		++ k;
		
		for (int j = i + i; j <= X; j += i) cont[j] = true;
	}
}


int main()
{
	freopen ("ciur.in", "r", stdin);
	freopen ("ciur.out", "w", stdout);
	
	int N;
	
	scanf ("%d", &N);
	
	ciur (N);
	
	printf ("%d", k);
	
	return 0;
}