Pagini recente » Cod sursa (job #2215673) | Cod sursa (job #1115295) | Cod sursa (job #2547532) | Cod sursa (job #1063409) | Cod sursa (job #2788192)
#include <fstream>
#include <bitset>
using namespace std;
const int NMAX = 2e6;
bitset <1+NMAX> c;
//bool c[1+NMAX];
int main()
{
ifstream in("ciur.in");
ofstream out("ciur.out");
int n;
in >> n;
in.close();
for (int i = 2; i * i <= n; i++)///parcurg numerele ale caror multipli pot fi nemarcati si mai mici ca n
{
if (!c[i])///daca i este prim
{
for (int j = i * i; j <= n; j += i)///parcurgem multiplii lui i
{
c[j] = true;
}
}
}
int nr = 0;///nr. de numere prime mai mici sau egale cu n
for (int i = 2; i <= n; i++)
{
if (!c[i])
{
nr++;
}
}
out << nr;
out.close();
return 0;
}