1 #include<iostream>
2 #include<cstdio>
3 #include<cmath>
4 #include<cstring>
5 using namespace std;
6 int vis[100000001];
7 int ans[100000001];
8 int now;
9 int tot;
10 int main()
11 {
12 int n;
13 cin>>n;
14 long long int fw=pow(10,n);
15 long long int bg=pow(10,n-1);
16 for(int i=2;i<=sqrt(fw+0.5);i++)
17 {
18 if(vis[i]==0)
19 {
20 for(int j=i*i;j<=fw;j=j+i)
21 vis[j]=1;
22 }
23 }//筛法求素数
24 for(int i=bg;i<=fw;i++)//枚举范围内的每一个数
25 {
26 if(vis[i]==1)continue;
27 else
28 {
29 int sum=0,m;
30 m=i;
31 while(m)
32 {
33 sum=sum*10+m%10;// sum为反复取的个位数加上次的sum的10倍
34 m/=10;//反复缩小10倍
35 }
36 if(sum==i)
37 {
38 tot++;
39 ans[now]=i;
40 now++;
41 }
42 }
43 }
44 cout<<tot<<endl;
45 for(int i=0;i<now;i++)
46 cout<<ans[i]<<" ";
47 return 0;
48 }