给定一个非负整数 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:
//0 1 1 2 1 2 2 3 1 2 2 3 2 3 3 4 1
vector<int> countBits(int num) {
vector<int> ans;
for(int i=0;i<=num;i++){
if(i==0){
ans.push_back(0);
}else if(i%2==1){
ans.push_back(ans[i-1]+1);
}else{
ans.push_back(ans[i/2]);
}
}
return ans;
}
};