每日一题 338. 比特位计数

鼠扑  金牌会员 | 2024-12-23 13:16:20 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 870|帖子 870|积分 2610

338. 比特位计数

难点是发现规律
  1. class Solution {
  2. public:
  3.     vector<int> countBits(int n) {
  4.         
  5.         vector<int> dp(n+1,0);
  6.         if(n <=0)
  7.         {
  8.             return dp;
  9.         }
  10.         dp[1] = 1;
  11.         if(n == 1)
  12.         {
  13.             return dp;
  14.         }
  15.         int bin = 0;
  16.         for(int i=2;i<=n;++i)
  17.         {
  18.             int base = getBinary(i);
  19.             dp[i] = dp[i-(1<<base)] + 1;
  20.         }
  21.         return dp;
  22.     }
  23.     int getBinary(int num)
  24.     {
  25.         int ret = 0;
  26.         while( num != 0)
  27.         {
  28.             num  = num >> 1;
  29.             ++ret;
  30.         }
  31.         return ret-1;
  32.     }
  33. };
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

鼠扑

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表