素数回文
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 21780 Accepted Submission(s): 5081
Problem Description
xiaoou33对既是素数又是回文的数特别感兴趣。比如说151既是素数又是个回文。现在xiaoou333想要你帮助他找出某个范围内的素数回文数,请你写个程序找出 a 跟b 之间满足条件的数。(5 <= a < b <= 100,000,000);
Input
这里有许多组数据,每组包括两组数据a跟b。
Output
对每一组数据,按从小到大输出a,b之间所有满足条件的素数回文数(包括a跟b)每组数据之后空一行。
Sample Input
5 500
Sample Output
5711101131151181191313353373383
Author
xiaoou333
思路:枚举10000内的所有素数,并根据这个数拼接出另一半,构成回文数,并判断是否为素数。另外拼接时只需考虑奇数个回文数,因为偶数回文(除11外)都是11的倍数。
AC代码:
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
const int maxn = 1e6;
int save[maxn];
int vist[maxn];
int t[10];
int a,b;
int divid(int j){ //拆分并判断是否为回文
memset(t,-1,sizeof(t));
int cnt=0;
while(j){
t[cnt++] = j%10;
j /= 10;
}
int fg = 1;
for(int i = 0; i < cnt/2; i++){
int tmp = t[i];t[i]=t[cnt-i-1];t[cnt-i-1]=tmp;
if(t[i] != t[cnt-i-1]) fg = 0;
}
return fg;
}
int con1(){ //拼接成回文数
int cnt = 0;
int sum = 0;
for(int i = 0; t[i] != -1; i++){
sum = sum * 10 + t[i];
cnt++;
}
for(int i = cnt-2;i >= 0; i--){
sum = sum * 10 + t[i];
}
return sum;
}
int isSuShu(int i){ //判断是否为素数
for(int j = 2; j <= sqrt(i); j++){
if(i % j == 0) return 0;
}
return 1;
}
int main(){
int cnt = 0;
for(int i = 1; i <= 10000; i++){ //打表记录
if(divid(i) && isSuShu(i)) save[cnt++] = i;
int cn1 = con1();
if(cn1 <= 10000) continue;
if(isSuShu(cn1)) save[cnt++] = cn1;
}
sort(save,save+cnt);
while(scanf("%d%d",&a,&b) == 2){
for(int i = 0; i < cnt; i++){
if(save[i] >= a && save[i] <= b){
printf("%d\n",save[i]);
}
if(save[i] > b) break;
}
printf("\n");
}
return 0;
}