Cod sursa(job #147271)

Utilizator taloibogdanTaloi Bogdan Cristian taloibogdan Data 2 martie 2008 18:59:10
Problema Ciurul lui Eratosthenes Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.49 kb
#include<stdio.h>
#include<string.h>
long n,i,l,j,s[1024];
char a[2000010];
int main()
{
 freopen("ciur.in","r",stdin);
 freopen("ciur.out","w",stdout);
 scanf("%d",&n);
 for(i=2;i<=n;++i)
    if(a[i]==0)
      {++l;
       for(j=i*i;j<=n;j+=i) if(j<=n) a[j]=1;
      }
 printf("%d\n",l);
 i=0;
 for(j=n;j>1;--j)
    if(j>1)
      if(a[j]==0)
	if((i<1000)&&(i<=l))
	  s[++i]=j;
		       else
          break;
 for(;i;--i)if(i>0)printf("%d ",s[i]);
 printf("\n");
 return 0;
}