找出输入区间内的回文质数

假设输入区间为[a, b],a>0,则回文质数满足以下条件:
1.为质数(废话)
2.必须为回文数(正着看倒着看是一样),但这个回文数的位数必须为奇数位(11除外),为什么呢?
   因为位数为偶数的回文数必然是11的倍数,即它不是质数,具体证明如下:
   对于数字abcd,abcd = 1000*a + 100*b + 10*c + d = (1100*a - 110*a + 11*a - a) + (110*b - 11*b + b) + (11*c - c) + d = (1100*a - 110*a + 11*a) + (110*b - 11*b) + 11*c + (b + d - a - c),从最后的式子可以看出前三项都是11的倍数,最后一项(b + d - a -c)为0,因为根据回文数的性质可知 b == c, a == d,从而证明了abcd不是质数。

从上面的两个性质,便可写出相应的函数,然后进行判断,在判断的时候,先判断是否为回文数,再判断是否为质数,因为在区间内,回文数往往比质数少。(记得排除11)

 

 
  
#include < iostream >
using namespace std;

// whether the value is odd bits and is a palindrome number, except 11
bool is_oddbits_palindrome_number( int value);
// whether value is prime
bool is_prime( int value);
int main()
{
int a;
int b;
scanf(
" %d%d " , & a, & b);
for ( int i = a; i <= b; i ++ )
{
// is_oddbits_palindrome_number is revoked first
if (is_oddbits_palindrome_number(i) && is_prime(i))
printf(
" %d\n " , i);
}
return 0 ;
}

bool is_oddbits_palindrome_number( int value)
{
char s[ 16 ];
itoa(value, s,
10 );
int bits = strlen(s);
// odd bits
if ( ! (bits % 2 ) && value != 11 )
return false ;
// whether is palindrome
for ( int i = 0 ; i < bits / 2 ; i ++ )
{
if (s[i] != s[bits - 1 - i])
return false ;
}
return true ;
}

bool is_prime( int value)
{
int middle = value / 2 ;
for ( int i = 2 ; i <= middle; i ++ )
if ( ! (value % i))
return false ;
return true ;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值