package java_huaweijishi;
import java.util.Scanner;
/**
* 题目:功能:输入一个正整数,按照从小到大的顺序输出它的所有质数的因子(如180的质数因子为2 2 3 3 5 ),最后一个数后面也要有空格
详细描述:
函数接口说明:
public String getResult(long ulDataInput)
输入参数:
long ulDataInput:输入的正整数
返回值:
String
* @author hexiaoli
*
*/
public class PrimeFactor {
public static void main(String[] args) {
//输入整数
Scanner inputInteger = new Scanner(System.in);
//临时存储正整数
long number = 0;
//如果一直有输入,则放入getResult中找质数因子
while(inputInteger.hasNextLong()){
number = inputInteger.nextLong();
System.out.println(getResult(number));
}
}
public static String getResult(long ulDataInput){
StringBuilder str = new StringBuilder();
if(ulDataInput <= 1){
return "请输入大于1的正整数";
}
while(ulDataInput != 1){
for(int i=2;i<=ulDataInput;i++){
//i是ulDataInput的质数因子,写入到str中
if(ulDataInput % i == 0){
str.append(i+" ");
ulDataInput/=i;
break;
}
}
}
return str.toString();
}//end getResult
}
华为机试(6)质数因子
猜你喜欢
转载自blog.csdn.net/hxl0925/article/details/91038850
今日推荐
周排行