码迷,mamicode.com
首页 > 其他好文 > 详细

HDU 1431 素数回文(回文素数)

时间:2014-11-16 16:02:38      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:acm   algorithm   算法   

HDU 1431 素数回文(回文素数)

http://acm.hdu.edu.cn/showproblem.php?pid=1431

题意:

       给你两个整数a,b。(5 <= a < b <= 100,000,000)要你按顺序输出[a,b]区间内的所有回文素数。

分析:

       定理:如果一个数是回文且有偶数位,那么它能被11整除。

     根据上面定理我们可知我们只需要找到区间[2,1000W)内的素数即可。(想想为什么)上面b的范围直接缩小了10倍。

       剩下的工作就是用筛选法求出1000W内的所有素数,然后对于给定的a和b,我们对于[a,b]区间内的每个素数判断,看其是否是回文,如果是回文就输出。

AC代码

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxn=10000000;

//求素数
bool flag[maxn];//flag[i]==true->i不是素数
int prime[1000000+5];
int get_prime()
{
    for(int i=2;i<=maxn;i++)
    {
        if(flag[i]==false) prime[++prime[0]]=i;
        for(int j=1;j<=prime[0]&&prime[j]<=maxn/i;j++)
        {
            flag[prime[j]*i]=true;
            if(i%prime[j]==0) break;
        }
    }
    return prime[0];
}

//判断x是否回文
bool check(int x)
{
    int a=x;
    int b=0;
    while(a)
    {
        b=b*10+a%10;
        a/=10;
    }
    return b==x;
}

int main()
{
    get_prime();

    int a,b;
    while(scanf("%d%d",&a,&b)==2)
    {
        int L=lower_bound(prime+1,prime+prime[0]+1,a)-prime;
        for(int i=L;i<=prime[0] && prime[i]<=b;i++)
        {
            if(check(prime[i])) printf("%d\n",prime[i]);
        }
        printf("\n");
    }
    return 0;
}

HDU 1431 素数回文(回文素数)

标签:acm   algorithm   算法   

原文地址:http://blog.csdn.net/u013480600/article/details/41173237

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!