因式分解:求素数乘积

public class Main {
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        while (in.hasNextInt()) {
            int n = in.nextInt();
            boolean hasPrime = false;
            for(int i=2; i<=Math.sqrt(n); i++){
                if(n / i * i == n && isPrime(i) && isPrime(n / i)){
                    hasPrime = true;
                    System.out.println(i + "," + n/i);
                }
            }
            if(!hasPrime) System.out.println("没有");
        }
    }

    public static boolean isPrime(int n){
        if(n == 2 || n == 3) return true;
        for(int i=2; i<=Math.sqrt(n); i++){
            if(n / i * i == n) return false;
        }
        return true;
    }
}
全部评论

相关推荐

头像
04-29 10:53
已编辑
东北大学 自动化类
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务