Pagini recente » Cod sursa (job #2386941) | Cod sursa (job #1793613) | Cod sursa (job #3143928) | Cod sursa (job #1124797) | Cod sursa (job #963734)
Cod sursa(job #963734)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("ciur.in");
ofstream g("ciur.out");
#ifndef _ciur_h
#define _ciur_h
#include <bitset>
#include <vector>
#include <cmath>
#define max_size 2000013
class ciur
{
public:
ciur(){ generate(); }
void generate(){
int i = 2, l = (int)sqrt(max_size);
for(int i=2;i<max_size;i++) bit[i]=1;
while(i <= l)
{
if(!bit[i]){ i++; continue; }
for(int j=i*i;j<max_size;j+=i) bit[j] = 0;
i++;
}
}
bool isprime(int x){
return bit[x];
}
private:
bitset<max_size>bit;
};
#endif
int n, x = 0;
ciur a;
int main()
{
f >> n;
for(int i=0;i<n;i++)
if(a.isprime(i)) x++;
g << x << endl;
return 0;
}