各位相加
给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数。返回这个结果。
实例
输入: num = 38
输出: 2
解释: 各位相加的过程为:
38 --> 3 + 8 --> 11
11 --> 1 + 1 --> 2
由于 2 是一位数,所以返回 2。
代码:
public int addDigits(int num) {
if(num>9){
num=num%9;
if(num==0){
return 9;
}
}
return num;
}
原理:
num 给位数分别是ijk
num = i*100+j*10+k=i*99+j*9+i+j+k
如果i+j+k>9 有 num%9=(i+j+k)%9=最终结果