/*
Cred : SunnyYeahBoi
It's my last chance (⌐■_■)
Problem :
*/
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define double long double
#define endl "\n"
#define NAME "a"
const int MAXN = 1e6 + 5;
const int inf = 1e18;
const int MOD = 1e9 + 7;
void FileInput(){
if(fopen(NAME".inp" , "r") == NULL)
freopen(NAME".inp" , "w" , stdout);
freopen(NAME".inp" , "r" , stdin);
freopen(NAME".out" , "w" , stdout);
}
int n;
const int N = 1e6 + 5;
bool isPrime[N + 1];
void sang(){
for(int i = 0 ; i <= N ; i++)
isPrime[i] = true;
isPrime[0] = isPrime[1] = false;
for(int i = 2 ; i <= N ; i++){
if(isPrime[i]){
for(int j = 2 * i ; j <= N ; j += i) // 2i , 3i , 4i , ...
isPrime[j] = false;
}
}
}
void solve(){
sang();
cin >> n;
for(int i = 2 ; i <= n ; i++){
if(isPrime[i])
cout << i << " ";
}
}
int32_t main(){
FileInput();
ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0);
int t = 1;
// cin >> t;
while(t--)
solve();
return 0;
}
LyoKICAgIENyZWQgOiBTdW5ueVllYWhCb2kKICAgIEl0J3MgbXkgbGFzdCBjaGFuY2UgKOKMkOKWoF/ilqApCiAgICBQcm9ibGVtIDoKKi8KCiNpbmNsdWRlPGJpdHMvc3RkYysrLmg+Cgp1c2luZyBuYW1lc3BhY2Ugc3RkOwoKI2RlZmluZSBpbnQgbG9uZyBsb25nCiNkZWZpbmUgZG91YmxlIGxvbmcgZG91YmxlCiNkZWZpbmUgZW5kbCAiXG4iCiNkZWZpbmUgTkFNRSAiYSIKCmNvbnN0IGludCBNQVhOID0gMWU2ICsgNTsKY29uc3QgaW50IGluZiA9IDFlMTg7CmNvbnN0IGludCBNT0QgPSAxZTkgKyA3OwoKdm9pZCBGaWxlSW5wdXQoKXsKICAgIGlmKGZvcGVuKE5BTUUiLmlucCIgLCAiciIpID09IE5VTEwpCiAgICAgICAgZnJlb3BlbihOQU1FIi5pbnAiICwgInciICwgc3Rkb3V0KTsKICAgIGZyZW9wZW4oTkFNRSIuaW5wIiAsICJyIiAsIHN0ZGluKTsKICAgIGZyZW9wZW4oTkFNRSIub3V0IiAsICJ3IiAsIHN0ZG91dCk7Cn0KCmludCBuOwoKY29uc3QgaW50IE4gPSAxZTYgKyA1Owpib29sIGlzUHJpbWVbTiArIDFdOwoKdm9pZCBzYW5nKCl7CiAgICBmb3IoaW50IGkgPSAwIDsgaSA8PSBOIDsgaSsrKQogICAgICAgIGlzUHJpbWVbaV0gPSB0cnVlOwogICAgaXNQcmltZVswXSA9IGlzUHJpbWVbMV0gPSBmYWxzZTsKICAgIGZvcihpbnQgaSA9IDIgOyBpIDw9IE4gOyBpKyspewogICAgICAgIGlmKGlzUHJpbWVbaV0pewogICAgICAgICAgICBmb3IoaW50IGogPSAyICogaSA7IGogPD0gTiA7IGogKz0gaSkgLy8gMmkgLCAzaSAsIDRpICwgLi4uCiAgICAgICAgICAgICAgICBpc1ByaW1lW2pdID0gZmFsc2U7CiAgICAgICAgfQogICAgfQp9Cgp2b2lkIHNvbHZlKCl7CiAgICBzYW5nKCk7CiAgICBjaW4gPj4gbjsKICAgIGZvcihpbnQgaSA9IDIgOyBpIDw9IG4gOyBpKyspewogICAgICAgIGlmKGlzUHJpbWVbaV0pCiAgICAgICAgICAgIGNvdXQgPDwgaSA8PCAiICI7CiAgICB9Cn0KCmludDMyX3QgbWFpbigpewogICAgRmlsZUlucHV0KCk7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKDApO2Npbi50aWUoMCk7Y291dC50aWUoMCk7CiAgICBpbnQgdCA9IDE7CiAgICAvLyBjaW4gPj4gdDsKICAgIHdoaWxlKHQtLSkKICAgICAgICBzb2x2ZSgpOwogICAgcmV0dXJuIDA7Cn0K