题解 | #质数因子#
质数因子
http://www.nowcoder.com/practice/196534628ca6490ebce2e336b47b3607
思路直接,理解上比较简单,效率上相对差一些。
import java.util.*;
public class Main {
    public static void main(String args[]) {
        Scanner sc = new Scanner(System.in);
        int num = sc.nextInt();
        StringBuilder sb = new StringBuilder();
        // 遍历所有的因子,取值到平方根即可
        for (int i = 2; i * i <= num; i++) {
            while (num % i == 0) {
            	// 对于2,3连续且已知的因子直接添加
                if (i <= 3) {
                    sb.append(i).append(" ");
                    // 对num去除当前因子重新赋值
                    num /= i;
                    continue;
                }
				
                // 用于判断是否是质数
                boolean isAdd = true;
                // 遍历所有的因子,取值到平方根即可
                for (int j = 2; j * j <= i; j++) {
                    if (i % j == 0) {
                    	// 如果存在除了1和自身之外的因子就不是质数
                        isAdd = false;
                        break;
                    }
                }
                
                // 是质数,就添加
                if (isAdd) {
                    sb.append(i).append(" ");
                }
                
                // 对num去除当前因子重新赋值
                num /= i;
            }
        }
		
        // 循环结束最后不是1的因子也是质数,直接添加
        if (num != 1) {
            sb.append(num);
        }
		
        // 输出结果
        System.out.print(sb);
    }
}
 投递中国电信等公司10个岗位
投递中国电信等公司10个岗位