剑指OfferII003.前n个数字二进制中1的个数

题目

给定一个非负整数 n ,请计算 0 到 n 之间的每个数字的二进制表示中 1 的个数,并输出一个数组。

示例 1:输入: n = 2 输出: [0,1,1]

解释: 0 --> 0

1 --> 1

2 --> 10

示例 2:输入: n = 5 输出: [0,1,1,2,1,2]

解释:0 --> 0

1 --> 1

2 --> 10

3 --> 11

4 --> 100

5 --> 101

说明 :0 <= n <= 105

进阶:给出时间复杂度为 O(n*sizeof(integer)) 的解答非常容易。但你可以在线性时间 O(n) 内用一趟扫描做到吗?

要求算法的空间复杂度为 O(n) 。

你能进一步完善解法吗?要求在C++或任何其他语言中不使用任何内置函数(如 C++ 中的 __builtin_popcount )来执行此操作。

注意:本题与主站 338 题相同

解题思路分析

1、位运算;时间复杂度O(n),空间复杂度O(n)

func countBits(n int) []int {
   res := make([]int, n+1)
   for i := 1; i <= n; i++ {
      res[i] = res[i&(i-1)] + 1
   }
   return res
}

2、动态规划;时间复杂度O(n),空间复杂度O(n)

剑指OfferII003.前n个数字二进制中1的个数

func countBits(n int) []int {
   dp := make([]int, n+1)
   for i := 1; i <= n; i++ {
      if i%2 == 0 {
         dp[i] = dp[i/2]
      } else {
         dp[i] = dp[i-1] + 1
      }
   }
   return dp
}

3、暴力法;时间复杂度O(n),空间复杂度O(n)

func countBits(n int) []int {
   res := make([]int, 0)
   for i := 0; i <= n; i++ {
      count := 0
      value := i
      for value != 0 {
         if value%2 == 1 {
            count++
         }
         value = value / 2
      }
      res = append(res, count)
   }
   return res
}

4、内置函数;时间复杂度O(n),空间复杂度O(n)

func countBits(n int) []int {
   res := make([]int, 0)
   for i := 0; i <= n; i++ {
      count := bits.OnesCount(uint(i))
      res = append(res, count)
   }
   return res
}

总结

Easy题目,题目同leetcode 338.比特位计数

展开阅读全文

页面更新:2024-05-27

标签:个数   进阶   本题   复杂度   解法   整数   数组   示例   线性   算法   函数   暴力   题目   数字   时间   科技   空间

1 2 3 4 5

上滑加载更多 ↓
推荐阅读:
友情链接:
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号

Top