Mai intai trebuie sa te autentifici.
Cod sursa(job #603117)
| Utilizator | Data | 14 iulie 2011 16:55:54 | |
|---|---|---|---|
| Problema | Ciurul lui Eratosthenes | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.99 kb |
/*#include<iostream>
#include<fstream>
char a[1000000],b[1000000];
using namespace std;
int main(void)
{
long long i,j,n,terminat=0,/*a[700000],b[700000],*//*e,nrdiv=1,putere,maxd,min,contor=0;
fstream f,g;
f.open("ciur.in",ios::in);
g.open("ciur.out",ios::out);
f>>n;
for (i=0;i<(n-1)/2;i++)
a[i]=2*i+3;
b[0]=2;j=0;
while (!terminat)
{
for (i=0;i<(n-1)/2;i++)
if (a[i]%b[j]==0)
a[i]=0;
for (i=0;a[i]==0;i++);
if (i<(n-1)/2)
{j++; b[j]=a[i];}
else
terminat=1;
}
g<<j+1;
}
*/
#include<iostream>
#include<fstream>
#include <stdio.h>
using namespace std;
int N, cnt;
char prim[2000005];
int main(void)
{
int i,j;
fstream f,g;
f.open("ciur.in", ios::in);
g.open("ciur.out", ios::out);
f>>N;
for (i = 2; i <= N; ++i)
prim[i] = 1;
for (i = 2; i <= N; ++i)
if (prim[i])
{
++cnt;
for (j = i+i; j <= N; j += i)
prim[j] = 0;
}
g<<cnt;
}