質數因子
目之所及,皆是回憶;心之所想,皆是過往;眼之所看,皆是遺憾,
背景:Java 在線編程機試刷題,
題目描述:
輸入一個正整數,按照從小到大的順序輸出它的所有質因子(重復的也要列舉)(如180的質因子為2 2 3 3 5 )最后一個數后面也要有空格,
輸入描述:
輸入一個long 型整數,
輸出描述:
按照從小到大的順序輸出它的所有質數的因子,以空格隔開,最后一個數后面也要有空格,
示例1:
輸入:
180輸出:
2 2 3 3 5Java代碼:
1 import java.util.Scanner;
2
3 public class Main{
4
5 public static void main(String [] args){
6 Scanner scan = new Scanner(System.in);
7 long input = scan.nextLong();
8 if(input >= 2){
9 System.out.print(qualitiesNum(input));
10 }else{
11 // 2是最小的質數
12 return;
13 }
14 scan.close();
15 }
16
17 private static String qualitiesNum(long input){
18 int smallestQuality = 2;
19 StringBuilder sb = new StringBuilder();
20 while(input >= smallestQuality){
21 if(input % smallestQuality == 0){
22 if(input == smallestQuality){
23 sb.append(smallestQuality).append(" ");
24 break;
25 }else{
26 input = input / smallestQuality;
27 sb.append(smallestQuality).append(" ");
28 }
29 }else{
30 smallestQuality++;
31 }
32 }
33 return sb.toString();
34 }
35
36 }
輸出驗證:

目之所及 皆是回憶
心之所想 皆是過往
眼之所看 皆是遺憾
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/360.html
標籤:Java
