质数因子
2018-01-07 14:41
260 查看
题目描述
功能:输入一个正整数,按照从小到大的顺序输出它的所有质数的因子(如180的质数因子为2 2 3 3 5 )最后一个数后面也要有空格
详细描述:
函数接口说明:
public String getResult(long ulDataInput)
输入参数:
long ulDataInput:输入的正整数
返回值:
String
输入描述:
输入一个long型整数
输出描述:
按照从小到大的顺序输出它的所有质数的因子,以空格隔开。最后一个数后面也要有空格。示例1
输入
180
输出
2 2 3 3 5
解析:分解质因数,对于一个整数,从2开始去除,若能整除,则得到一个该数的质因数,然后得到的商作为新的被除数,若不能整除,则除数加1.,直到除数小于被除数为止。
实现代码:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
Main obj = new Main();
long num = sc.nextLong();
String str = obj.getResult(num);
System.out.print(str);
}
public String getResult(long ulDataInput){
String str="";
int i = 2;
while(i<=ulDataInput){
if (ulDataInput % i == 0 ){
str = str + String.valueOf(i) + " ";
ulDataInput /=i;
}else{
i++;
}
}
return str;
}
}
相关文章推荐
- 质数因子
- 求质数因子
- 输入一个正整数,按照从小到大的顺序输出它的所有质数的因子(如180的质数因子为2 2 3 3 5 )
- 找出一个合数的最大质数因子
- c++训练题(求某个数的最大质数因子)兼自己写的一个打印一定范围内质数方法
- 质数因子
- 华为OJ 初级:质数因子
- [编程题]质数因子
- #109D Colliders 素数筛 统计质数因子 data[j][ ++data[j][0] ] = prime[i];
- 分解一个long整数为质数因子相乘
- 华为机试-质数因子
- 华为6质数因子
- hiho 挑战赛7(有钱就是任性-dp与质数的因子)
- 华为OJ——质数因子
- 质数因子
- 质数因子
- PAT 1096. Consecutive Factors (20)(最大连续乘积因子)(sqrt(n)判断一个数是否为质数的深刻理解)
- 质数因子
- 输入一个正整数,按照从小到大的顺序输出它的所有质数的因子(如180的质数因子为2 2 3 3 5 )
- 华为上机题之质数因子