2012.9.15 Leetcode 258. Add Digits

Given a non-negative integer num, repeatedly add all its digits until the result has only one digit.

For example:

Given num = 38, the process is like: 3 + 8 = 11, 1 + 1 = 2. Since 2 has only one digit, return it.

Follow up:
Could you do it without any loop/recursion in O(1) runtime?

這道題最終返回的是一位的數,也就是0—9中的某個數字,用數字推理即可得出規律,發現好多題都是要用筆劃幾下~
————————————————————————————
<u>num</u>——<u>返回結果</u>
0——0
1——1
···
9——9
10——1
11——2
···
18——9
19——1
20——2
···
27——9
···
——————————————————————————————
逐漸驗算的過程中發現,每到9的倍數的時候,返回的都是9,在那之前是從1開始逐漸遞增的,也就是每9個一循環,輸入距離是9,所以這道題的解法也就出來了
<u>Runtime: 6 ms</u>

class Solution {
public:
    int addDigits(int num) {
        if(num == 0)//0時單獨對待
            return 0;
        else if(num%9 == 0){//9的倍數的時候單獨對待
            return 9;
        }else{//否則其他情況,返回9的模
            return num%9;
        }
    }
};
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容