leetcode, 338题【比特位计数】
2021/10/30 23:12:51
本文主要是介绍leetcode, 338题【比特位计数】,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
比特位计数
- 题目描述
- 测试用例
- 算法
- 1.利用位运算
- 2.神解法
题目描述
给你一个整数 n ,对于 0 <= i <= n 中的每个 i ,计算其二进制表示中 1 的个数 ,返回一个长度为 n + 1 的数组 ans 作为答案。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/counting-bits
测试用例
示例 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
算法
1.利用位运算
//i & (i - 1)可以去掉i最右边的一个1(如果有),因此 i & (i - 1)是比 i 小的,而且i & (i - 1)的1的个数已经在前面算过了,所以i的1的个数就是 i & (i - 1)的1的个数加上1 class Solution { public int[] countBits(int n) { int[] res = new int[n + 1]; for (int i = 1; i <= n; i++) { res[i] = res[i & (i -1)] + 1; //动态规划 } return res; } }
2.神解法
//对于一个二进制数来说,如果它的最低位为1(%2 为 1),则它与 n/2 的 1 个数相差1。 如果它的最低位为 0,则它与 n/2 的 1 个数相同 这样就可以用前面的推出后面的 class Solution { public int[] countBits(int n) { int[] res = new int[n + 1]; for(int i = 0; i<= n /2; i++) { res[i * 2] = res[i]; if(i * 2 + 1 <= n) { res[i * 2 + 1] = res[i] + 1; } } return res; } } ``
这篇关于leetcode, 338题【比特位计数】的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-07-05feign默认connecttimeout和readtimeout是多少-icode9专业技术文章分享
- 2024-07-05idea控制台,日志太多,导致部分想看得日志被刷走 搜不到-icode9专业技术文章分享
- 2024-07-05The server selected protocol version Tls10 is not accepted by client preferences [TLs12]-icode9专业技术文章分享
- 2024-07-05怎么清理项目缓存-icode9专业技术文章分享
- 2024-07-04安装 Eyoucms详细图文教程-icode9专业技术文章分享
- 2024-07-04ueditor 复制文章时,图片的链接是一个下载图片地址,该如何处理?-icode9专业技术文章分享
- 2024-07-04怎样判断host有没有对wordpress有缓存呢-icode9专业技术文章分享
- 2024-07-04具有编译功能的系统make后,无法ssh连接-icode9专业技术文章分享
- 2024-07-04make后如何升级ssh-icode9专业技术文章分享
- 2024-07-03微信支付提示下单账户与支付账户不一致-icode9专业技术文章分享