题目描述:
给定一个非负整数 num。对于 0 ≤ i ≤ num 范围中的每个数字 i ,计算其二进制数中的 1 的数目并将它们作为数组返回。
示例 1:
输入: 2
输出: [0,1,1]
示例 2:
输入: 5
输出: [0,1,1,2,1,2]
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/counting-bits
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
题解:
class Solution {
public:
vector<int> countBits(int num)
{
vector<int> res(num+1,0);
res[0] = 0;
for(int i=1;i<=num;++i)
{
if(i%2 == 1)
res[i] = res[i-1]+1;
else
res[i] = res[i/2];
}
return res;
}
};
解题思路:
一个数如果是奇数,那么它的二进制位中1的个数就是它前一个偶数中1的个数再加一;
一个数如果是偶数,那么它的二进制位中的1的个数和它的二分之一的那个数的1的个数一样。