Leetcode 剑指 Offer II 003. 前 n 个数字二进制中 1 的个数
admin
2024-02-17 01:32:00
0

题目难度: 简单

原题链接

今天继续更新 Leetcode 的剑指 Offer(专项突击版)系列, 大家在公众号 算法精选 里回复 剑指offer2 就能看到该系列当前连载的所有文章了, 记得关注哦~

题目描述

给定一个非负整数 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 <= 10^5

进阶:

  • 给出时间复杂度为 O(n*sizeof(integer)) 的解答非常容易。但你可以在线性时间 O(n) 内用一趟扫描做到吗?
  • 要求算法的空间复杂度为 O(n) 。
  • 你能进一步完善解法吗?要求在 C++或任何其他语言中不使用任何内置函数(如 C++ 中的 __builtin_popcount )来执行此操作。

题目思考

  1. 如何做到线性时间一趟扫描?
  2. 前后数字之间是否有关联?

解决方案

思路

  • 分析题目, 一个很容易想到的方法就是从 0 遍历到 N, 然后依次统计每个数字的二进制 1 的数目 (不断右移并检查最低位数字, 是 1 则累加计数)
  • 但这种算法的时间复杂度是 O(n*sizeof(integer)), 如何达到题目里的进阶要求 (线性时间一趟扫描) 呢?
  • 如果在计算后面数字的 1 的个数时, 能利用之前数字的计算结果, 这样我们就无需诸位统计了
  • 例如对于二进制数 0b1011 来说, 它有 3 个 1, 相比 0b1010 多了最低位的 1
  • 这样就可以将问题转换成求将最低位 1 翻转成 0 的数字了, 那如何求解呢?
  • 如果当前数字 n 的个位是 1, 显然 n-1 就可以将最低位翻转成 0 了, 那对于个位不是 1 的数字呢?
  • 此时 n 的最低位 1 后面一定全是 0, 所以 n 长这样: 0bxxx1000, n-1 的话就是 0bxxx0111
  • 那么将 n-1 与 n 求与, 得到的结果就是 0bxxx0000, 正是将 n 的最低位 1 翻转成 0 的数字
  • 综合上述两种情况, n&(n-1) 即可得到 1 的数目比 n 少 1 的数字 (因为即使个位是 1, n&(n-1)还是 n-1)
  • 所以 n 的 1 的数目就是 n&(n-1)的 1 的数目加 1
  • 我们依次从 1 开始遍历到 n, 利用上述规则即可在线性时间内一趟扫描求出所有数字的 1 的数目

复杂度

  • 时间复杂度 O(N): 线性时间, 一趟扫描
  • 空间复杂度 O(N): 最终结果数组需要存 N 个数字

代码

class Solution:def countBits(self, n: int) -> List[int]:res = [0] * (n + 1)for mask in range(1, n + 1):# pre是mask将最低位1变成0后的数字pre = mask & (mask - 1)# mask相比pre多了一个1res[mask] = res[pre] + 1return res

大家可以在下面这些地方找到我~😊

我的 GitHub

我的 Leetcode

我的 CSDN

我的知乎专栏

我的头条号

我的牛客网博客

我的公众号: 算法精选, 欢迎大家关注~😊

相关内容

热门资讯

斗金订购APP贵金属期货投资被...   斗金订购APP的投资者被广告宣传给诱导,注册就送什么现金,然后充值返现金卷等等这些宣传方式,都是...
哈易购APP非法期货交易欺骗投...   哈易购APP宣传可做白银铂金贵金属订购交易,但实际上并没有取得相关交易资质!哈易购APP本质上就...
消息称百度旗下昆仑芯瞄准500... 6 月 29 日消息,据《The Information》昨日援引知情人士消息,百度旗下 AI 芯片...
打造夏日消费新场景 第35届北... 北京商报讯(记者 翟枫瑞)6月29日消息,第35届北京国际燕京啤酒文化节新闻发布会在京举行。本届啤酒...
社保基金持仓数据出炉,一季度增... 最近各大上市公司一季度财报都公开了,咱们国家社保基金的持仓数据也全部曝光。目前社保拿着比亚迪价值44...
36氪首发 | 海思、中兴团队... 作者 | 乔钰杰 编辑 | 袁斯来 硬氪获悉,广州宸思通讯科技有限公司(以下简称“宸思科技”)近日完...
两天蒸发47亿市值!一纸税务通... 一纸税务通知书,能让一家百亿龙头两天蒸发47亿市值。 6月22日,北大荒(600598.SH)公告称...
SK海力士将投资1100万亿韩... SK集团会长崔泰源6月29日在韩国“三大重大计划”发布会上宣布,公司将投资1100万亿韩元扩大半导体...
两只A股,终止上市! 两家A股公司,即将摘牌。 6月29日,退市沪科(600608.SH)公告称,上海证券交易所将在202...
原创 M... 一家成立近十年的自动驾驶公司,在IPO时吸引了14家基石投资者认购近一半的发行股份,其中不乏奔驰、比...
基金忠言|国寿安保滤镜碎,三年... 图片来源:视觉中国 蓝鲸新闻6月29日讯(记者 祁和忠)保险系基金公司国寿安保总经理换人了。 6月2...
三星电机计划加码玻璃基板!相关... 6月29日,玻璃基板概念股午后有所回升, 华工科技(000988.SZ)逼近涨停, 彩虹股份(600...
拉萨海关持续壮大外贸经营主体 ...   新华网拉萨6月28日电(记者蒋梦辰)近日,记者从拉萨海关获悉,今年前5个月,西藏有进出口实绩的外...
机构:二季报临近,医药生物板块... 6月29日,华源证券发布了一篇医药生物行业的研究报告,报告指出,业绩期临近,产业链景气度有望再次迎来...
每日收评科创50放量涨超4.5... 财联社6月29日讯,三大指数全线收红,创业板指探底回升,科创50指数大涨4.61%。沪深两市成交额3...
6月多地土拍结构性升温:深圳单... 进入2026年6月,不少城市核心区地块集中诞生高溢价宗地,热度突出的城市包含深圳、杭州、长沙。 其中...
业绩炸裂!盛达资源半年预盈3.... 6月29日,贵金属矿山龙头盛达资源(000603.SZ)发布 2026 年半年度业绩预告,上半年业绩...
A股午后拉升三大股指收涨:半导... A股三大股指6月29日开盘涨跌互现。早盘沪强深弱,创指一度跌超2%。半导体午后拉升,带动两市上涨,沪...
原创 空... 前言 大家好,我是老金。 这几天,两幅极度割裂的画面放在一起,把我看笑了。 一边是在持续的热浪下,欧...