试题 算法提高 分解质因数
资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
给定一个正整数n,尝试对其分解质因数
输入格式
仅一行,一个正整数,表示待分解的质因数
输出格式
仅一行,从小到大依次输出其质因数,相邻的数用空格隔开
样例输入
100
样例输出
2 2 5 5
数据规模和约定
n<=2147483647
不多说,直接看代码即可:
import java.util.*;
public class Main {
public static int n;
public static Scanner in = new Scanner(System.in);
public static void main(String[] args) {
n = in.nextInt();
if( n == 1 || n == 0 ) {
System.out.println(n);
return;
}
for( int i = 2; i <= n; i++) {
if( n % i == 0 ) { // 如果当前数字可以整除 n
while( n % i == 0 ) { // 不断用这个数字去除 n,直到不可整除
System.out.print(i + " "); // 直接打印
n /= i; // 更新 n
}
}
if( n == 1 ) return; // 如果只剩下 1 了,即已经完成了因数分解,直接退出程序
if( isPrime(n) ) { // 为了不超时,在此处需要判断是否为质数,若为质数,则直接输出
System.out.print(n);
return;
}
}
System.out.print(n);
in.close();
}
private static boolean isPrime(int n) {
if( n == 2 ) return true;
if( n % 2 == 0 ) return false;
for( int i = 3; i <= Math.sqrt(n); i+=2) {
if( n % i == 0 ) return false;
}
return true;
}
public static void find() {
for( int i = 2; ; i++) {
if( n % i == 0 ) {
System.out.print(i + " ");
n /= i;
while( n % i == 0 ) {
System.out.print(i + " ");
n /= i;
}
return;
}
}
}
}