博客
关于我
Leetcode 338. 比特位计数 (二进制位dp递推,和通常的整数有区别)
阅读量:238 次
发布时间:2019-03-01

本文共 595 字,大约阅读时间需要 1 分钟。

这题的特殊之处在于采用了二进制位的递推方法,而不是传统的动态规划(dp)方式。这种方法通过对二进制位进行递推来计算数位的数量。

递推方法解释

举个例子来理解这一点可能会更清楚:比如,数字11001可以分解为1100 + 1&1。这里的1&1实际上是对最低有效位进行操作,相当于将最低有效位单独提取出来。

代码解析

以下是实现这一递推方法的C++代码:

class Solution {
public:
vector
countBits(int num) {
vector
dp(num + 1);
for (int i = 1; i <= num; ++i) {
dp[i] = dp[i >> 1] + (i & 1);
}
return dp;
}
};

递推逻辑

  • dp[i] = dp[i >> 1] + (i & 1)
  • 这里的dp[i >> 1]表示将i右移一位后的结果,相当于去掉了最低有效位。
  • (i & 1)则是提取出i的最低有效位,值为0或1。
  • 因此,dp[i]实际上是i的二进制位数,比如i=3(二进制为11),dp[3]=dp[1]+1=3

这种递推方法通过逐位处理数字,避免了传统dp的复杂性,简化了数位计算过程。

转载地址:http://scqv.baihongyu.com/

你可能感兴趣的文章
NPOI在Excel中插入图片
查看>>
NPOI将某个程序段耗时插入Excel
查看>>
NPOI格式设置
查看>>
NPOI设置单元格格式
查看>>
Npp删除选中行的Macro录制方式
查看>>
NR,NF,FNR
查看>>
nrf24l01+arduino
查看>>
nrf开发笔记一开发软件
查看>>
nrm —— 快速切换 NPM 源 (附带测速功能)
查看>>
nrm报错 [ERR_INVALID_ARG_TYPE]
查看>>
NS3 IP首部校验和
查看>>
NSDateFormatter的替代方法
查看>>
NSError 的使用方法
查看>>
NSGA-Ⅲ源代码
查看>>
nsis 安装脚本示例(转)
查看>>
NSJSON的用法(oc系统自带的解析方法)
查看>>
nslookup 的基本知识与命令详解
查看>>
NSNumber与NSInteger的区别 -bei
查看>>
NSOperation基本操作
查看>>
NSRange 范围
查看>>