回文素数

一个数同时为素数和回文数,显示前100个回文素数
代码:
package com.im;

public class Demo626 {

public static void main(String[] args) {
    // TODO Auto-generated method stub

// long Num = 1000000000;
int count = 1;

    for(int i=2; true; i++){


        if(isPrimeNum(i) && isPalindrome(i)){
            System.out.printf("%6d",i);

            if(count%10 == 0){
                System.out.println();
            }

            if(count == 100){
                break;
            }
            count++;
        }
    }

}

//判断是否是素数
public static boolean isPrimeNum(long Num){

    for(int i=2; i<=Num/2; i++){
        if(Num % i == 0){
            return false;
        }
    }
    return true;
     //如果Num不存在 
}

//判断是否是回文数
public static boolean isPalindrome(long Num){
    if(Num == reverse(Num)){
        return true;
    }else{
        return false;
    }
}

//求出此数的倒置数
public static long reverse(long Num){

    long v = 0; //位数上的数字
    long m = 0;  //倒置数
    int count = digitOfNumber(Num);

    for(int i=1; i<=count; i++){
        v = Num % 10;
        m += v*Math.pow(10, count-i);
        Num /= 10;
    }

    return m;

}

//求出此数的位数
public static int digitOfNumber(long Num){

    int count = 0; //位数的计数器
    while(Num > 0){
        Num /= 10;
        count++;
    }
    return count;
} 

}
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值