LeetCode 258. 各位相加题解

258. 各位相加题解

题目来源:258. 各位相加

2022.03.03 每日一题

每日一题专栏地址:LeetCode 每日一题题解更新中❤️💕

法一:模拟

今天的题目就很简单啦,只需要简单的模拟一下就可以啦

class Solution {
public:
    int addDigits(int num) {
        int res = 0;
        while (num != 0) {
            res += (num % 10);
            num /= 10;
        }
        if (res > 9) return addDigits(res);
        return res;
    }
};
class Solution {
    public int addDigits(int num) {
        int res = 0;
        while (num != 0) {
            res += (num % 10);
            num /= 10;
        }
        if (res > 9) return addDigits(res);
        return res;
    }
}

法二:数学

能够被9整除的整数,各位上的数字加起来也必然能被9整除,所以,连续累加起来,最终必然就是9。

使用模九法

我们将数字137以十进制分成堆

137 = 1 ∗ 100 + 3 ∗ 10 + 7 ∗ 1 137=1*100+3*10+7*1 137=1100+310+71,我们可以发现是有 11 11 11个堆的

但是这种比较麻烦,我们也可以这么查
$137=1100+310+71\=1(100-1)+1+3*(100-1)+3+7*1=1
KaTeX parse error: Expected 'EOF', got '&' at position 5: 137&̲=&1*100+3*10+7*…
现在就得到了小于 10 的数字,但是如果换一个数字呢

例如这个数字是945呢?99+399+(1但是这种比较麻烦,我们也可以这么查
KaTeX parse error: Expected 'EOF', got '&' at position 5: 137&̲=&&1*100+3*10+7…
括号里面的数字就是堆的个数(加和的数目)

但是 1 + 3 + 7 1+3+7 1+3+7 的值是11大于9了,那我们就要继续分堆了
KaTeX parse error: Expected 'EOF', got '&' at position 5: 137&̲=&1*100+3*10+7*…
现在就得到了小于 10 的数字,但是如果换一个数字呢

例如这个数字是945呢?

我们会发现最后的数字变成了 0 ,那么就可以进行+3+7)$
括号里面的数字就是堆的个数(加和的数目)

但是 1 + 3 + 7 1+3+7 1+3+7 的值是11大于9了,那我们就要继续分堆了
KaTeX parse error: Expected 'EOF', got '&' at position 4: 137&̲=&1*100+3*10+7*…
现在就得到了小于 10 的数字,但是如果换一个数字呢

例如这个数字是945呢?

我们会发现最后的数字变成了 0 ,那么就可以进行优化一下,将原本数字进行减一操作后,再进行加一操作,就得到了 9

class Solution {
public:
    int addDigits(int num) {
        return (num - 1) % 9 + 1;
    }
};
class Solution {
    public int addDigits(int num) {
        return (num - 1) % 9 + 1;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值