给你一个整数 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
方法一:数学
我们将
时间复杂度
class Solution:
def sumBase(self, n: int, k: int) -> int:
ans = 0
while n:
ans += n % k
n //= k
return ans
class Solution {
public int sumBase(int n, int k) {
int ans = 0;
while (n != 0) {
ans += n % k;
n /= k;
}
return ans;
}
}
class Solution {
public:
int sumBase(int n, int k) {
int ans = 0;
while (n) {
ans += n % k;
n /= k;
}
return ans;
}
};
func sumBase(n int, k int) (ans int) {
for n > 0 {
ans += n % k
n /= k
}
return
}
/**
* @param {number} n
* @param {number} k
* @return {number}
*/
var sumBase = function (n, k) {
let ans = 0;
while (n) {
ans += n % k;
n = Math.floor(n / k);
}
return ans;
};
function sumBase(n: number, k: number): number {
let ans = 0;
while (n) {
ans += n % k;
n = Math.floor(n / k);
}
return ans;
}
impl Solution {
pub fn sum_base(mut n: i32, k: i32) -> i32 {
let mut ans = 0;
while n != 0 {
ans += n % k;
n /= k;
}
ans
}
}
int sumBase(int n, int k) {
int ans = 0;
while (n) {
ans += n % k;
n /= k;
}
return ans;
}