1 import java.util.Scanner; 2 3 /** 4 * 給定一個非負整數 num,反復將各個位上的數字相加,直到結果為一位數。 5 6 示例: 7 8 輸入: 38 輸出: 2 9 解釋: 各位相加的過程為:3 + 8 = 11, 1 + 1 = 2。 由於 2是一位數,所以返回 2。 10 */ 11 public class TestSum { 12 public static void main(String[] args) { 13 Scanner scanner = new Scanner(System.in); 14 while (scanner.hasNext()) { 15 int num = scanner.nextInt(); 16 System.out.println("輸出:" + addDigits(num)); 17 // System.out.println("輸出:" + addDigits02(num)); 18 } 19 scanner.close(); 20 } 21 22 //1.for/while/遞歸,可以如下直接處理,或者放到int數組,或者轉成String, charAt(i), 23 // 如下的做法最簡單 24 public static int addDigits(int num) { 25 int sum = 0; 26 while (num > 9) { 27 sum = 0; 28 while (num > 0) { 29 sum += num % 10; //個位 30 num /= 10; // 十位。。。 31 } 32 num = sum; 33 } 34 return num; 35 } 36 37 /** 38 * 進階寫法 : 不使用循環或者遞歸,且在 O(1) 時間復雜度內解決這個問題 39 題解 : 假設一個三位數整數n=100a+10b+c,變化后addn=a+b+c; 40 兩者的差值n-addn=99a+9b,差值可以被9整除,說明每次縮小9的倍數 41 那么我們可以對res=num%9,若不為0則返回res,為0則返回9 42 * @param num 43 * @return 44 */ 45 public static int addDigits02(int num) { 46 if (num == 0) { 47 return 0; 48 } 49 return (num % 9 == 0) ? 9 : num % 9; 50 } 51 }