质数算法优化问题,一道落谷算法题。

 

落谷的题目,详见图片,代码如下:

 

package 题目一;

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        int m = in.nextInt();
        for(;n<=m;n++)
        {
            if(pDZ(n))
            {
                if(pDH(n))
                {
                    System.out.println(n);
                }
            }
        }
    }

    private static boolean pDH(int n) {
        int x=n;
        int m=0;
        while(x!=0)
        {
            m=m*10+x%10;
            x/=10;
        }
        if(m==n)
        {
            return true;
        }
        return false;
    }

    private static boolean pDZ(int n) {
        if(n==2||n==3)
        {
            return true;
        }
        if(n%6!=1&&n%6!=5)
        {
            return false;
        }
        else
        {
            for(int i = 5;i<=(int)(Math.sqrt(n));i+=6)
            {
                if(n%i==0||n%(i+2)==0)
                {
                    return false;
                }
            }
        }
        return true;
    }
}

 

好难啊!大佬快救救我!

网上看了下,没啥快速的算法,我整理了下比较快速的方法你自己实现下

不要遍历所有的数,自己生成范围内的非偶回文数,然后判断是不是质数

质数的判断方式是不能被1到根号n的数整除

感觉这样应该最快了