Pagini recente » Cod sursa (job #2094815) | Cod sursa (job #2929967) | Cod sursa (job #806090) | Cod sursa (job #1782171) | Cod sursa (job #144965)
Cod sursa(job #144965)
#include <stdio.h>
#include <fstream>
using namespace std;
#define in "ciur.in"
#define out "ciur.out"
#define dim 2000001
int N;
int Nr[1001];
bool Sel[dim];
int main()
{
int size = 0, total = 1;
freopen(in,"r",stdin);
freopen(out,"w",stdout);
scanf("%d", &N);
memset(Sel,0,sizeof(Sel));
for ( int i = 2; i*i <= N; i++ )
{
if ( Sel[i] ) continue;
for ( int j = 2; i*j <= N; j++ )
{
if ( !Sel[i*j] ) total++;
Sel[i*j] = 1;
}
}
total = N - total;
for ( int i = N; i >= 2; i-- )
{
if ( !Sel[i] ) Nr[++size] = i;
if ( size == 1000 ) break;
}
printf("%d\n",total);
for ( ; size; size-- )
printf("%d ", Nr[size]);
}