首页 >web前端 >js教程 >LeetCode 冥想:计算比特

LeetCode 冥想:计算比特

Barbara Streisand
Barbara Streisand原创
2024-12-27 16:41:10689浏览

LeetCode Meditations: Counting Bits

计数位的描述如下:

给定一个整数 n,返回一个数组 ans 长度 n 1 这样对于每个 i (0 , ans[i] 数字 1 的二进制表示中 i.

例如:

Input: n = 2
Output: [0, 1, 1]

Explanation:
0 --> 0
1 --> 1
2 --> 10

或者:

Input: n = 5
Output: [0, 1, 1, 2, 1, 2]

Explanation:
0 --> 0
1 --> 1
2 --> 10
3 --> 11
4 --> 100
5 --> 101

该问题要求我们获取从 0 到 n 的每个数字的二进制表示形式中 1 的数量。

我想到的第一个解决方案是创建一个长度为 n 1 的数组,用二进制的 0 到 n 的值填充它......

const arr = Array.from({ length: n + 1 }, (_, i) => i.toString(2));

...并将每一位映射到它所具有的 1 位数:

arr.map(j => {
  let result = 0;
  let binaryNumber = parseInt(j, 2);
  while (binaryNumber > 0) {
    binaryNumber &= binaryNumber - 1;
    result++;
  }
  return result;
});

请注意,在上一个问题中,我们使用了一种技术来计算 1 位的数量(或计算其 汉明权重)——它只是从数字中减去一个较小的值,直到达到0:

let numberOf1Bits = 0;
while (binaryNumber > 0) {
  binaryNumber &= binaryNumber - 1;
  numberOf1Bits++;
}

我们可以链接这些方法,总的来说,解决方案如下所示:

function countBits(n: number): number[] {
  return Array.from({ length: n + 1 }, (_, i) => i.toString(2)).map(j => {
    let result = 0;
    let binaryNumber = parseInt(j, 2);
    while (binaryNumber > 0) {
      binaryNumber &= binaryNumber - 1;
      result++;
    }
    return result;
  });
}

或者,我们可以更明确地编写它,将每个计数推送到结果数组:

Input: n = 2
Output: [0, 1, 1]

Explanation:
0 --> 0
1 --> 1
2 --> 10

时间和空间复杂度

对设置的位进行计数有 log n登录n 登录 时间复杂度(在最坏的情况下,当所有位都已设置时,循环将运行 binaryNumber 中的位数 — 数字的二进制表示形式的位数 nn n log n登录n 登录 ).
然而我们也这样做 nn n 次,所以总的来说,时间复杂度为 O(n log nO(n log n) O(n log n) .

空间复杂度为 O(n)O(n) O(n) 随着结果数组对空间的需求增加 nn n 增加。


接下来,我们将看看反向位。在那之前,祝您编码愉快。

以上是LeetCode 冥想:计算比特的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn