Cod sursa(job #152398)
Utilizator | Data | 9 martie 2008 13:56:26 | |
---|---|---|---|
Problema | Ciurul lui Eratosthenes | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.39 kb |
#include<fstream.h>
#define nmax 2000001
char nr[nmax];
long long i,n,j,x[1002],p=0;
int main(){
ifstream f("ciur.in");
ofstream g("ciur.out");
f>>n;
for(i=2;i<=n;i++) nr[i]=1;
for(i=2;i<=n;i++)
if(nr[i]!=0)
for(j=i+i;j<=n;j+=i)
nr[j]=0;
for(i=n;i>1&&p<=1000;i--)
if(nr[i]==1)
x[p++]=i;
g<<p<<"\n";
for(i=p-1;i>0;i--)
g<<x[i]<<" ";
g<<x[i];
return 0;
}