筛法求素数 6分
2018-06-17 23:09:29来源:未知 阅读 ()
11:回文素数
- 查看
- 提交
- 统计
- 提问
- 总时间限制:
- 5000ms
- 内存限制:
- 65536kB
- 描述
- 一个数如果从左往右读和从右往左读数字是相同的,则称这个数是回文数,如121,1221,15651都是回文数。给定位数n,找出所有既是回文数又是素数的n位十进制数。(注:不考虑超过整型数范围的情况)。
- 输入
- 位数n,其中1<=n<=9。
- 输出
- 第一行输出满足条件的素数个数。
第二行按照从小到大的顺序输出所有满足条件的素数,两个数之间用一个空格区分。 - 样例输入
-
1
- 样例输出
-
4 2 3 5 7
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 }
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:运算符重载 与 sort()
下一篇:05:素数回文数的个数
- Prime Time UVA - 10200(精度处理,素数判定) 2019-08-16
- 简单的素数问题(C++) 2019-01-23
- 素数判定 2019-01-11
- PAT (Basic Level) Practice 1007 素数对猜想 2018-12-04
- 判断是不是素数 2018-12-04
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash