返回介绍

solution / 1800-1899 / 1837.Sum of Digits in Base K / README

发布于 2024-06-17 01:03:14 字数 2705 浏览 0 评论 0 收藏 0

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

English Version

题目描述

给你一个整数 n10 进制)和一个基数 k ,请你将 n10 进制表示转换为 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

解法

方法一:数学

我们将 $n$ 除 $k$ 取余,直至为 $0$,余数相加即可得到结果。

时间复杂度 $O(\log_{k}n)$,空间复杂度 $O(1)$。

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
}
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
  }
}
/**
 * @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;
};
int sumBase(int n, int k) {
  int ans = 0;
  while (n) {
    ans += n % k;
    n /= k;
  }
  return ans;
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文