题解 | #质数因子#

质数因子

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) {
                if (i <= 3) {
                    sb.append(i).append(" ");
                    num /= i;
                    continue;
                }

                boolean isAdd = true;
                for (int j = 2; j * j <= i; j++) {
                    if (i % j == 0) {
                        isAdd = false;
                        break;
                    }
                }
                if (isAdd) {
                    sb.append(i).append(" ");
                }
                num /= i;
            }
        }

        if (num != 1) {
            sb.append(num);
        }

        System.out.print(sb);
    }
}
全部评论

相关推荐

05-01 22:41
中南大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务