給定一個非負整數 num,反復將各個位上的數字相加,直到結果為一位數。


 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 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



猜您在找 給定一個非負整數 num,反復將各個位上的數字相加,直到結果為一位數。 給定一個非負整數 num,反復將各個位上的數字相加,直到結果為一位數 Leetcode練習(Python):第258題:各位相加:給定一個非負整數 num,反復將各個位上的數字相加,直到結果為一位數。 給定一個非負整數 num,反復將各個位上的數字相加,直到結果為一位數。(如何在類里面寫遞歸) 202008xx給定一個整數n(1<=n<=1000000000),要求從個位開始分離出它的每一位數字,從個位開始按照從低位到高位的順序依次輸出每一位數字(奧賽一本通p64 4題) java基礎練習 給定一個正整數m,統計m的位數,分別打印每一位數字,再按照逆序打印出各位數字。 輸入一個由4位數字組成的整數,把它分解為單個數字,然后輸出每一位數字。 給出兩個 非空 的鏈表用來表示兩個非負的整數。其中,它們各自的位數是按照 逆序 的方式存儲的,並且它們的每個節點只能存儲 一位 數字。 如果,我們將這兩個數相加起來,則會返回一個新的鏈表來表示它們的和。 給出兩個 非空 的鏈表用來表示兩個非負的整數。其中,它們各自的位數是按照 逆序 的方式存儲的,並且它們的每個節點只能存儲 一位 數字。 如果,我們將這兩個數相加起來,則會返回一個新的鏈表來表示它們的和。 【c語言】輸入一個整數,將每一位數字輸出
 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM