题目描述
功能:输入一个正整数,按照从小到大的顺序输出它的所有质数的因子(如180的质数因子为2 2 3 3 5 )
最后一个数后面也要有空格
详细描述:
函数接口说明:
public String getResult(long ulDataInput)
输入参数:
long ulDataInput:输入的正整数
返回值:
String
输入描述:
输入一个long型整数
输出描述:
按照从小到大的顺序输出它的所有质数的因子,以空格隔开。最后一个数后面也要有空格。
示例1
输入
180
输出
2 2 3 3 5
答案
import java.util.Scanner;
import sun.reflect.ReflectionFactory.GetReflectionFactoryAction;
public class Main {
static String s = "";
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
long input = sc.nextLong();
getResult(input);
}
}
public static void getResult(long ulDataInput) {
for(int i = 2; i < ulDataInput+1; i++){
if(ulDataInput%i==0){
if(isPrime(i)){
//s = s + ;
System.out.print(i + " ");
getResult(ulDataInput/i);
return;
}
}
}
}
public static boolean isPrime(int n)
{
int i;
for (i = 2; i <= n; i++)
{
if (n%i == 0)
{
break;
}
}
if (i >= n)
{
return true;
}
else {
return false;
}
}
}