Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/341.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
我正试图为我的AP计算机科学课程编写一个素因子分解Java代码,我被卡住了_Java - Fatal编程技术网

我正试图为我的AP计算机科学课程编写一个素因子分解Java代码,我被卡住了

我正试图为我的AP计算机科学课程编写一个素因子分解Java代码,我被卡住了,java,Java,} 我遇到的问题是,我无法让它打印出超过jsut的每个数字。例如,如果你输入16,它只会给你一个2,而不是4个2。我使用checkprime是因为我的教授让我们,我知道你可以不用它来做这个程序。我是新来的,非常感谢你的建议 我遇到的问题是,我无法让它打印出超过jsut的每个数字 那是因为i++;印刷之后。与其继续使用下一个潜在的除数,不如一直使用同一个除数,直到除数消失 您不应该增加除数,而应该将其从num中除掉。例如,如果您看到num=24可被2整除,请打印2,并使num=12。下一次迭代将再

}

我遇到的问题是,我无法让它打印出超过jsut的每个数字。例如,如果你输入16,它只会给你一个2,而不是4个2。我使用checkprime是因为我的教授让我们,我知道你可以不用它来做这个程序。我是新来的,非常感谢你的建议

我遇到的问题是,我无法让它打印出超过jsut的每个数字

那是因为i++;印刷之后。与其继续使用下一个潜在的除数,不如一直使用同一个除数,直到除数消失


您不应该增加除数,而应该将其从num中除掉。例如,如果您看到num=24可被2整除,请打印2,并使num=12。下一次迭代将再次打印2,并使num=6。下面的迭代将最后一次打印2,并使num=3。此时,您的算法可以转到下一个除数,并打印3。

一些建议:阅读。使用调试器。多喝水。检查这里:还有很多关于素数的副本。这里你犯了很多错误,比如循环到number而不是sqrtnumber,找到它时不除以因子,…非常感谢
public boolean checkPrime( int number )
{
    int divisor = 2;
    int remainder = 1; 
    while(number != divisor)
    {
        remainder = number % divisor ;
        if( remainder == 0)
        {
            return false ;
        }
        else
        {
            divisor ++ ;
        }

    }
    return true ;  
}


public void primeFactors ( int num )
{
    int i = 2 ;
    while(  i <= num)

    {

        if( num % i == 0)
        {
            boolean isPrime = checkPrime( i );
            checkPrime( i ) ;
            if( isPrime )
            {
                System.out.print("," + i);
                i++;
            }
            else
            {
                i++;
            }
        }
        else
        {
            i++ ;
        }
    }
}