AddDigitsTotal - 把数字中单个数相加

简介: 给定一个int数字,把数字中的单个数相加起来;得到的结果如果不是个位数,继续相加 如给定 19,执行1+9 = 10 --> 1 + 0 = 1  返回1 给定22,返回4 思路很简单,把各个位置上的数字取出来相加;结果如果大于9,继续执行相加 Java代码实现: 1 public ...

给定一个int数字,把数字中的单个数相加起来;得到的结果如果不是个位数,继续相加

如给定 19,执行1+9 = 10 --> 1 + 0 = 1  返回1

给定22,返回4

思路很简单,把各个位置上的数字取出来相加;结果如果大于9,继续执行相加

Java代码实现:

 1 public class AddDigitsTotal {
 2     public static int addOnce(int n) {
 3         int result = 0;
 4         while (n != 0) {
 5             result += n%10;
 6             n = n/10;
 7         }
 8         return result;
 9     }
10 
11     public static int addDigits(int num) {
12         int res = 0;
13         res = addOnce(num);
14         while (res > 9) {
15             res = addOnce(res);
16         }
17         return res;
18     }
19     public static void main(String args[]){
20         for (int i = 900; i < 919; i++) {
21             System.out.print((i) + "\t");
22         }
23         System.out.println();
24         for (int i = 900; i < 919; i++) {
25             System.out.print(addDigits(i) + "\t");
26         }
27         for (int i = 0; i < 10000; i++) {
28             if (addDigits(i) >= 10) {
29                 System.out.print("ERROR");
30             }         
31         }
32     }
33 }

 输出:

900	901	902	903	904	905	906	907	908	909	910	911	912	913	914	915	916	917	918	
9	1	2	3	4	5	6	7	8	9	1	2	3	4	5	6	7	8	9	

  

 

目录
相关文章
|
3月前
|
Python
如果一个n位正整数等于其各位数字的n次方之和
如果一个n位正整数等于其各位数字的n次方之和
|
6月前
|
算法 测试技术 C#
C++数位算法:数字1的个数
C++数位算法:数字1的个数
|
4月前
[leetcode 数位计算]2520. 统计能整除数字的位数
[leetcode 数位计算]2520. 统计能整除数字的位数
|
10月前
判断数字位数
判断数字位数
40 0
|
11月前
求一个数的二进制位中1的个数
求一个数的二进制位中1的个数
|
11月前
7-10 求数字个数
7-10 求数字个数
39 0
|
11月前
求整数的位数及各位数字之和
求整数的位数及各位数字之和
76 0
357. 计算各个位数不同的数字个数
357. 计算各个位数不同的数字个数
357. 计算各个位数不同的数字个数
输出最小的数位和等于x并且各个数位都不一样的值
输出最小的数位和等于x并且各个数位都不一样的值
33 0
打印0~100000之间的水仙花数, 水仙花数指一个n位数,其各位数的n次方之和正好等于该数本身
打印0~100000之间的水仙花数, 水仙花数指一个n位数,其各位数的n次方之和正好等于该数本身
84 0