LeetCode 1837. K 进制表示下的各位数字总和

给你一个整数 n(10 进制)和一个基数 k ,请你将 n 从 10 进制表示转换为 k 进制表示,计算并返回转换后各位数字的 总和 。

转换后,各位数字应当视作是 10 进制数字,且它们的总和也应当按 10 进制表示返回。

示例 1:

输入:n = 34, k = 6
输出:9
解释:34 (10 进制) 在 6 进制下表示为 54 。5 + 4 = 9 。

1 <= n <= 100
2 <= k <= 10

直接计算出n在k进制下的每一位,然后加起来即可:

class Solution {
public:
    int sumBase(int n, int k) {
        int digitSum = 0;
        while (n) {
            digitSum += n % k;
            n /= k;
        }

        return digitSum;
    }
};

此算法时间复杂度为O(lgn),空间复杂度为O(1)。

posted @   epiphanyy  阅读(20)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示