LeetCode 338. Counting Bits
来源:互联网 发布:淘宝onlyanna整容前后 编辑:程序博客网 时间:2024/04/20 10:53
比较容易想到的就是一个个数拿出来判断有几个1,判断时可以采用n&(n-1)来简化过程,不过时间复杂度明显就是O(n*sizeof(integer)).。
此外可以采用动态规划来做,对于一个大于1的整数,其二进制至少有2位,假设是n位,可以把它分成前(n-1)位和最后1位分别统计。
class Solution {public: vector<int> countBits(int num) { vector<int> cnt(num+1,0); if(num>0){ cnt[1]=1; for(int i=2;i<num+1;++i) cnt[i]=cnt[i>>1]+cnt[i&1]; } return cnt; }};
整体时间复杂度是O(n)
0 0
- [leetcode] 338. Counting Bits
- leetcode 338. Counting Bits
- [LeetCode]338. Counting Bits
- LeetCode#338. Counting Bits
- [LeetCode] 338. Counting Bits
- LeetCode 338. Counting Bits
- [LeetCode]338. Counting Bits
- LeetCode-338. Counting Bits
- LeetCode *** 338. Counting Bits
- (leetcode) 338. Counting Bits
- #leetcode#338. Counting Bits
- LeetCode 338. Counting Bits
- leetcode 338. Counting Bits
- LeetCode-338. Counting Bits
- LeetCode-338. Counting Bits
- leetcode-338. Counting Bits
- Leetcode 338. Counting Bits
- LeetCode 338. Counting Bits
- c语言前n项求和如何实现?2个方法可行的
- Deep Learning(深度学习)各种网址(持续更新)
- 在使用springmvc上传图片时碰到的 The current request is not a multipart request问题
- Java Web基础知识之Servlet(2):深入Servlet——HttpServlet
- 110. Balanced Binary Tree
- LeetCode 338. Counting Bits
- hdoj--2087 剪花布条
- 关于编译VOSM遇到的一些error(Windows)
- ASP.NET后台操作iframe跳转如何做呢
- 讯飞语音包实现Android语音识别
- iOS 获取手机型号,系统版本
- Android - JUnit Test(单元测试)
- 判断设备通知是否开启
- 工作准备