news 2026/6/9 18:48:14

Counting Bits LeetCode 高效解法解析与位运算技巧

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Counting Bits LeetCode 高效解法解析与位运算技巧

Counting Bits是LeetCode第338题,要求计算从0到给定整数n之间每个数字的二进制表示中1的个数。这个问题看似简单,但高效解法涉及位运算和动态规划的巧妙结合,是面试中考察候选人算法思维能力的经典题目。

counting bits leetcode题目是什么意思

这道题给定一个非负整数n,需要返回一个长度为n+1的数组,其中第i个元素表示数字i的二进制形式中1的个数。例如,当n=5时,二进制表示分别为0(0), 1(1), 2(10), 3(11), 4(100), 5(101),所以应该返回[0,1,1,2,1,2]。题目要求时间复杂度尽可能低,避免对每个数字单独计算。

理解题目后,最直接的思路是对每个数字计算其二进制中1的个数,但这会导致O(nsizeof(integer))的时间复杂度。在实际面试中,面试官通常期待更优的解法,这就需要我们深入分析数字二进制表示的内在规律。

counting bits leetcode如何高效解决

高效解决Counting Bits问题的关键在于发现相邻数字二进制表示之间的关系。通过观察可以发现,对于任意偶数i,其二进制中1的个数等于i/2的二进制中1的个数,因为偶数二进制最后一位是0,右移一位相当于除以2。对于奇数i,其二进制中1的个数等于i/2的二进制中1的个数加1。

基于这个规律,我们可以推导出状态转移方程:bits[i] = bits[i>>1] + (i & 1)。这里i>>1表示i右移一位(即除以2),i & 1用于判断i是否为奇数。这种方法只需一次遍历即可完成计算,时间复杂度为O(n),空间复杂度也为O(n)。

counting bits leetcode动态规划解法

上述解法本质上是一种动态规划思路,其中bits[i]表示状态,即数字i的二进制中1的个数。状态转移基于已计算的较小数字的结果,充分利用了子问题的解。具体实现时,初始化bits[0]=0,然后从1遍历到n,根据状态转移方程计算每个bits[i]。

在实际编码中,这个解法非常简洁高效。Python实现只需几行代码:def countBits(n): bits = [0]

(n+1); for i in range(1, n+1): bits[i] = bits[i>>1] + (i & 1); return bits。这种解法不仅高效,而且体现了将问题分解为子问题并重复利用结果的动态规划核心思想。

你在解决Counting Bits问题时是否考虑过其他优化方法?在实际面试中遇到这道题,你通常会如何向面试官解释解题思路?欢迎在评论区分享你的经验和看法,如果觉得这篇文章有帮助,请点赞和分享给更多正在准备技术面试的朋友。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/8 15:16:58

马士兵Java视频零基础教程:手把手教你学编程

很多Java初学者和转行者都接触过尚学堂马士兵老师的Java视频。这套视频以体系完整、讲解生动、实战性强著称,是我个人入门和提升的关键资源。它不仅能帮你构建扎实的Java基础,更能引导你理解编程思想,而不仅仅是语法。 马士兵Java视频适合零基…

作者头像 李华
网站建设 2026/6/7 7:03:39

中国船级社航:运低碳发展展望报告 2025

《航运低碳发展展望 2025》由中国船级社编制,立足全球视野,聚焦航运业净零转型进程,剖析政策演化、发展现状、核心挑战并提出系统解决方案,为行业各方提供决策参考。一、航运减排政策演化态势全球航运减排政策呈现 “区域先行、全…

作者头像 李华
网站建设 2026/6/7 6:16:52

AI率高背后的3个真相:为什么你写的也会被误判?

AI率高背后的3个真相:为什么你写的也会被误判? TL;DR(太长不看):很多同学明明是自己写的论文,AI率却高达60%、70%,这很冤枉但有原因。三个真相:学术写作风格本身就像AI(规…

作者头像 李华
网站建设 2026/6/7 12:31:29

百度WebUploader如何集成Vue大文件上传DEMO?

前端老哥外包救星:原生JS大文件上传组件(IE9兼容20G断点续传) 兄弟,作为甘肃接外包的前端程序员,我太懂你现在的处境了——客户要20G大文件上传,还要文件夹层级保留、IE9兼容、加密传输,预算还…

作者头像 李华
网站建设 2026/6/7 11:10:07

百度免费上传组件怎么结合Vue做大文件上传DEMO?

前端程序员外包项目救星:原生JS大文件上传组件(Vue3实现) 兄弟,作为在杭州接外包的老前端程序员,太懂你现在的处境了——甲方要20G大文件上传,还要兼容IE9,预算卡得死死的,网上代码…

作者头像 李华
网站建设 2026/6/7 11:12:57

Vue-cli怎样构建大文件分段上传DEMO?

武汉码农の大文件上传奇遇记:在长江边写信创代码 各位好,我是小王,武汉光谷某软件公司"防脱发小组"组长。最近接了个政府项目,要求在信创环境下上传4G文件,还必须开源可审查——这就像让我用热干面调料写火…

作者头像 李华