1837. K进制表示下的各位数字总和Java
文章发布较早,内容可能过时,阅读注意甄别。
# 题目
给你一个整数 n(10 进制)和一个基数 k ,请你将 n 从 10 进制表示转换为 k 进制表示,计算并返回转换后各位数字的 总和 。
转换后,各位数字应当视作是 10 进制数字,且它们的总和也应当按 10 进制表示返回。
示例 1:
输入:n = 34, k = 6
输出:9
解释:34 (10 进制) 在 6 进制下表示为 54 。5 + 4 = 9 。
示例 2:
输入:n = 10, k = 10
输出:1
解释:n 本身就是 10 进制。 1 + 0 = 1 。
提示:
- 1 <= n <= 100
- 2 <= k <= 10
# 思路
ArrayList
# 解法
class Solution {
public int sumBase(int n, int k) {
List<Integer> list=new ArrayList<Integer>();
while(n>=k){
int num=n/k;
list.add(n%k);
n=num;
}
list.add(n);
int sum_1=0;
for (Integer num:list) {
sum_1+=num;
}
return sum_1;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# 总结
- 分析出几种情况,然后分别对各个情况实现