Pagini recente » Cod sursa (job #2521358) | Cod sursa (job #3203857) | Cod sursa (job #381868) | Cod sursa (job #1811947) | Cod sursa (job #1097843)
/* Ciurul lui Erathostenes folosind bitset */
#include <cstdio>
#include <cmath>
#include <bitset>
#define MAX 2000001
using namespace std;
bitset<MAX> P;
void Ciur()
{
int i = 2, lim = sqrt(MAX);
while (i < lim)
{
while (P[i]) i++;
for (int j = i * i; j < MAX; j += i) P[j] = 1;
i++;
}
}
int main()
{
int N, K = 0;
freopen("ciur.in","r",stdin);
freopen("ciur.out","w",stdout);
Ciur();
scanf("%d", &N);
for (int i = 2; i <= N; i++)
if (!P[i]) K++;
printf("%d\n", K);
}