算法leetcode1837. K 进制表示下的各位数字总和(rust和go是真的好用)
Posted 二当家的白帽子
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法leetcode1837. K 进制表示下的各位数字总和(rust和go是真的好用)相关的知识,希望对你有一定的参考价值。
文章目录
1837. K 进制表示下的各位数字总和:
给你一个整数 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
分析
- 面对这道算法题目,二当家的陷入了沉思。
- 如果理解进制转换,这个问题就很好解决,我们从最末位开始,K进制表示满K进位,所以不满K的就会是最后一位,以此类推。
题解
rust
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
go
func sumBase(n int, k int) int
ans := 0
for n > 0
ans += n % k
n /= k
return ans
c++
class Solution
public:
int sumBase(int n, int k)
int ans = 0;
while (n > 0)
ans += n % k;
n /= k;
return ans;
;
java
class Solution
public int sumBase(int n, int k)
int ans = 0;
while (n > 0)
ans += n % k;
n /= k;
return ans;
python
class Solution:
def sumBase(self, n: int, k: int) -> int:
ans = 0
while n > 0:
ans += n % k
n //= k
return ans
原题传送门:https://leetcode.cn/problems/sum-of-digits-in-base-k/
非常感谢你阅读本文~
欢迎【点赞】【收藏】【评论】~
放弃不难,但坚持一定很酷~
希望我们大家都能每天进步一点点~
本文由 二当家的白帽子:https://le-yi.blog.csdn.net/ 博客原创~
以上是关于算法leetcode1837. K 进制表示下的各位数字总和(rust和go是真的好用)的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode1837. K 进制表示下的各位数字总和(C++)