1. 问题描述:
给你一个整数 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
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/sum-of-digits-in-base-k
2. 思路分析:
分析题目可以知道我们可以将当前的数字n转换为k进制,转换的时候每一次n除以k即可,在循环中模拟这个过程,只要是n大于0那么执行循环,n % k的值就是各个位置上的数值所以在求解的时候累加这些值即可
3. 代码如下:
class Solution:
def sumBase(self, n: int, k: int) -> int:
res = 0
while n > 0:
res += n % k
n //= k
return res