微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Java显示数字的Prime Factorization

因此,对于我的任务,我必须编写一个程序,要求用户输入整数输入,然后打印出该数字的素数因子分解.
这就是我所拥有的:
import java.util.Scanner;

public class PrimeFactor {
    public static void main(String[] args) {
        System.out.print("Enter a positive number: ");
        Scanner scanner = new Scanner (system.in);
        int number = scanner.nextInt();
        int count;
        for (int i = 2; i<=(number); i++) {
            count = 0;
            while (number % i == 0) {
                number /= i;
                count++;
                if (count == 0) {
                    continue;
                }
            }
            System.out.println(i+ "**" + count);
        }
    }
}

我现在遇到的问题是,无论何时我运行它,比如15453号,我得到一个从1到100的每个因子的列表及其指数,当我只想要素因子时,我被困在如何继续.

解决方法

你快到了!将if-continue块移到for循环之外.否则,它会“继续”最内层的循环,而不是你想要的循环.
while (number % i == 0) {
    number /= i;
    count++;
}
if (count == 0) {
    continue;
}
System.out.println(i+ "**" + count);

或者,您可以在if(count!= 0)中包含System.out.println调用,因为它是继续后面的唯一语句:

while (number % i == 0) {
    number /= i;
    count++;
}
if (count != 0) {
    System.out.println(i+ "**" + count);
}

您在ideone上的程序:link.

原文地址:https://www.jb51.cc/java/129899.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐