LeetCode-258 各位相加

一、题目描述

给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。

示例:

输入: 38
输出: 2
解释: 各位相加的过程为:3 + 8 = 11, 1 + 1 = 2。 由于 2 是一位数,所以返回 2。
进阶:
你可以不使用循环或者递归,且在 O(1) 时间复杂度内解决这个问题吗?

二、解题思路

假设一个整数为m=a+b10+c100+...,那么这个整数求取各位和后得到n=a+b+c+...,前后之间的差值为m-n=b*9 + c *99 + ...,可以很容易看出,差值是9的整数倍,因此输入m除以9后得到的余数即为我们需要的数,如果输入恰好是9的整数倍,则直接返回9。

三、代码实现

class Solution {
public:
    int addDigits(int num) {
        if(num > 9) {
            num %= 9;
            if(num == 0) {
                return 9;
            }
        }
        return num;
    }
};
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 题目描述 各位相加 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。 示例 输入: 38输出...
    一只可爱的柠檬树阅读 1,481评论 0 0
  • 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。 C++ 找规律。假如一个三位数'abc',...
    饼干不干阅读 3,499评论 0 51
  • 题目描述 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。 示例 1: 输入: 38 输出:...
    zhipingChen阅读 1,634评论 0 2
  • 题目 难度:★★☆☆☆类型:数学 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。 进阶:你...
    玖月晴阅读 4,933评论 0 0
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 9,043评论 0 2

友情链接更多精彩内容