动态规划(5)---Leetcode338.比特位计数

题目

给你一个整数 n ,对于 0 <= i <= n 中的每个 i ,计算其二进制表示中 1 的个数 ,返回一个长度为 n + 1 的数组 ans 作为答案。

分析

通常动态规划的做题顺序,先确定dp数组dp[i],然后确定确定递推公式,再dp数组初始化,最后确定递推顺序。

题解

java 复制代码
class Solution {
    public int[] countBits(int n) {
        int[] bits = new int[n + 1];
        int highBit = 0;
        for (int i = 1; i <= n; i++) {
            if ((i & (i - 1)) == 0) {
                highBit = i;
            }
            bits[i] = bits[i - highBit] + 1;
        }
        return bits;
    }
}
相关推荐
skytier17 小时前
Construct内报错和定位解决
算法
skytier17 小时前
Ascend print数据落盘使用
算法
etcix17 小时前
dmenux.c: integrate dmenu project as one file
c语言·前端·算法
papership17 小时前
【入门级-算法-6、排序算法:选择排序】
数据结构·算法·排序算法
汉克老师18 小时前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(4、最大空白区)
c++·算法·蓝桥杯·蓝桥杯c++·c++蓝桥杯
共享家952718 小时前
优先搜索(DFS)实战
算法·leetcode·深度优先
一只懒洋洋18 小时前
中值滤波、方框滤波、高斯滤波、均值滤波、膨胀、腐蚀、开运算、闭运算
算法·均值算法
shellvon18 小时前
你怎么被识别的?从TLS到Canvas的设备追踪术
后端·算法
薛定谔的算法18 小时前
JavaScript栈的实现与应用:从基础到实战
前端·javascript·算法
羚羊角uou18 小时前
【Linux】匿名管道和进程池
linux·c++·算法