每日一题 338. 比特位计数

338. 比特位计数

难点是发现规律

cpp 复制代码
class Solution {
public:
    vector<int> countBits(int n) {
        
        vector<int> dp(n+1,0);
        if(n <=0)
        {
            return dp;
        }
        dp[1] = 1;
        if(n == 1)
        {
            return dp;
        }
        int bin = 0;
        for(int i=2;i<=n;++i)
        {
            int base = getBinary(i);
            dp[i] = dp[i-(1<<base)] + 1; 
        }
        return dp;
    }

    int getBinary(int num)
    {
        int ret = 0;
        while( num != 0)
        {
            num  = num >> 1;
            ++ret;
        }
        return ret-1;
    }
};
相关推荐
冱洇3 小时前
168. Excel 表列名称
leetcode
mit6.82412 小时前
[Lc(2)滑动窗口_1] 长度最小的数组 | 无重复字符的最长子串 | 最大连续1的个数 III | 将 x 减到 0 的最小操作数
数据结构·c++·算法·leetcode
一只_程序媛15 小时前
【leetcode hot 100 54】螺旋矩阵
windows·leetcode·矩阵
柠石榴15 小时前
【练习】【二叉树】力扣热题100 102. 二叉树的层序遍历
c++·算法·leetcode·二叉树
邴越15 小时前
Leetcode 112: 路径总和
算法·leetcode·职场和发展
2301_8010377315 小时前
力扣-字符串
算法·leetcode·职场和发展
冠位观测者15 小时前
【Leetcode 每日一题】1328. 破坏回文串
数据结构·算法·leetcode
一只_程序媛15 小时前
【leetcode hot 100 53】最大子数组和
算法·leetcode·职场和发展
邴越15 小时前
Leetcode 57: 插入区间
算法·leetcode·职场和发展
自信的小螺丝钉16 小时前
Leetcode 1477. 找两个和为目标值且不重叠的子数组 前缀和+DP
算法·leetcode·前缀和·动态规划