这是悦乐书的第199次更新,第207篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第63题(顺位题号是258)。给定非负整数num,重复添加其所有数字,直到结果只有一位数。例如:

输入:38

输出:2

说明:过程如下:3 + 8 = 11,1 + 1 = 2。由于2只有一位数,所以请将其返回。

跟进:你可以在O(1)运行时间内没有任何循环/递归的情况下执行此操作吗?

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

特殊情况:如果num小于10,直接返回num即可。

正常情况:此解法是利用递归,因为每计算一次后得到的结果还是相同的问题。因为题目给定的是正整数,所以可以借助字符串来操作。先将num转为字符串,然后依次获取字符相加,得到每位数的和,然后继续调用自身。

public int addDigits(int num) {
if (num < 10) {
return num;
}
String str = num+"";
int sum = 0;
for (int i=0; i<str.length(); i++) {
sum += str.charAt(i)-'0';
}
return addDigits(sum);
}

03 第二种解法

特殊情况:如果num小于10,直接返回num即可。

正常情况:此解法是利用迭代,使用两层循环,外层判断大小,内层进行数据计算,先对10取余,再除以10,进入下一位接着计算,如果算到最后一位,跳出内层循环,此时还要加上对10取余的余数,因为内层循环只是做判断,然后将算出的和赋值给num,sum归为0,再开始下一次的循环。

public int addDigits2(int num) {
if (num < 10) {
return num;
}
int sum = 0;
while (num >= 10) {
while (num/10 != 0) {
sum += num%10;
num /= 10;
}
sum += num%10;
num = sum;
sum = 0;
}
return num;
}

04 第三种解法

可以先计算一部分数据,找找规律。

9 --> 9 --> 9%9=0 ?

10 --> 1 --> 10%9=1

13 --> 4 --> 13%9=4

18 --> 9 --> 18%9=0 ?

19 --> 1 --> 19%9=1

22 --> 4 --> 22%9=4

25 --> 7 --> 25%9=7

27 --> 9 --> 27%9=0 ?

29 --> 2 --> 29%9=2

33 --> 6 --> 33%9=6

36 --> 9 --> 36%9=0 ?

37 --> 1 --> 37%9=1

39 --> 3 --> 39%9=3

43 --> 7 --> 43%9=7

45 --> 9 --> 45%9=0 ?

46 --> 1 --> 46%9=1

49 --> 4 --> 49%9=4

通过上面这些数的计算,可以发现最后计算出的结果是有周期的,从1到9不断循环,并且除了9的倍数以外的数,其他的数都可以间接通过对9取余得到最后的结果,但是以9为倍数的整数,我们可以曲线救国,将原数减1后再对其取余,然后再把1补上。最后我们得到这样的公式:(num-1)%9 + 1。

public int addDigits3(int num) {
return (num-1)%9 + 1;
}

05 小结

算法专题目前已连续日更超过一个月,算法题文章63+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode算法题-Add Digits(Java实现-3种解法)的更多相关文章

  1. LeetCode算法题-Rotated Digits(Java实现)

    这是悦乐书的第316次更新,第337篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第185题(顺位题号是788).如果一个数字经过180度旋转后,变成了一个与原数字不同的 ...

  2. LeetCode算法题-Add Strings(Java实现)

    这是悦乐书的第223次更新,第236篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第90题(顺位题号是415).给定两个非负整数num1和num2表示为字符串,返回num ...

  3. LeetCode算法题-Add Binary(Java实现)

    这是悦乐书的第157次更新,第159篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第16题(顺位题号是67).给定两个二进制字符串,返回它们的总和(也是二进制字符串).输 ...

  4. LeetCode算法题-Heaters(Java实现)

    这是悦乐书的第239次更新,第252篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第106题(顺位题号是475).冬天来了!您在比赛期间的第一份工作是设计一个固定温暖半径 ...

  5. LeetCode算法题-Sqrt(Java实现)

    这是悦乐书的第158次更新,第160篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第17题(顺位题号是69). 计算并返回x的平方根,其中x保证为非负整数. 由于返回类型 ...

  6. LeetCode算法题-Subdomain Visit Count(Java实现)

    这是悦乐书的第320次更新,第341篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第189题(顺位题号是811).像"discuss.leetcode.com& ...

  7. LeetCode算法题-Unique Morse Code Words(Java实现)

    这是悦乐书的第318次更新,第339篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第186题(顺位题号是804).国际莫尔斯电码定义了一种标准编码,其中每个字母映射到一系 ...

  8. LeetCode算法题-Letter Case Permutation(Java实现)

    这是悦乐书的第315次更新,第336篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第184题(顺位题号是784).给定一个字符串S,将每个字母单独转换为小写或大写以创建另 ...

  9. LeetCode算法题-Minimum Distance Between BST Nodes(Java实现-四种解法)

    这是悦乐书的第314次更新,第335篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第183题(顺位题号是783).给定具有根节点值的二叉搜索树(BST),返回树中任何两个 ...

随机推荐

  1. Go基础系列:WaitGroup用法说明

    正常情况下,新激活的goroutine的结束过程是不可控制的,唯一可以保证终止goroutine的行为是main goroutine的终止.也就是说,我们并不知道哪个goroutine什么时候结束. ...

  2. [转]Docker修改默认时区

    本文转自:https://www.jianshu.com/p/004ddf941aac 前言 前段时间把公司部分项目迁移到了docker 容器里.查看ngixn反向代理的log时发现时间与正确时间相差 ...

  3. C-switch case之如何巧妙判断范围区域

    当判断整数时 示例: 判断整数范围 #include <stdio.h> int main() { unsigned ]={0x00,0x07,0x11,0x60,0x61,0x66}; ...

  4. MyBatis:自定义Mapper

    在开发中有时可能需要我们自己自定义一些mapper还有些一些自定义的xml,SQL语句.其实在我们的框架中很方便.只需要在mapper中添加自定义接口,在resources中自定义一个mapper的x ...

  5. java动态获取WebService的两种方式(复杂参数类型)

    java动态获取WebService的两种方式(复杂参数类型) 第一种: @Override public OrderSearchListRes searchOrderList(Order_Fligh ...

  6. Mysql Group by 使用解析

    使用gruop by 分组 1. 方式一:select name from table1 group by name; 注意:group by 两侧都应该含有name,例如select country ...

  7. bootstrap网站后台从设计到开发

    前言 毕业后在一家小公司找的工作是做前端,小公司必须要身兼多职,会多门技术,所以为了工作需要自学ps,做过微信运营,后来为了做erp管理系统,又开始学习c# ,之后公司有新项目要用wpf ,我又开始学 ...

  8. file 文件上传,下载,删除

    html: <div class="col-md-4 col-sm-4"> <div class="portlet light bordered&quo ...

  9. loj#6030. 「雅礼集训 2017 Day1」矩阵(贪心 构造)

    题意 链接 Sol 自己都不知道自己怎么做出来的系列 不难观察出几个性质: 最优策略一定是先把某一行弄黑,然后再用这一行去覆盖不是全黑的列 无解当且仅当无黑色.否则第一个黑色所在的行\(i\)可以先把 ...

  10. cf438E. The Child and Binary Tree(生成函数 多项式开根 多项式求逆)

    题意 链接 Sol 生成函数博大精深Orz 我们设\(f(i)\)表示权值为\(i\)的二叉树数量,转移的时候可以枚举一下根节点 \(f(n) = \sum_{w \in C_1 \dots C_n} ...