leetcode 338. 比特位计数

2023.12.28

简单的动态规划问题。 首先明确:当前为奇数时,比特数 = 当前数除以2的比特数;当前数为偶数时,比特数 = 当前数-1的比特数加上一

使用动态规划循序遍历即可,java代码如下:

java 复制代码
class Solution {
    public int[] countBits(int n) {
        if(n == 0) return new int[] {0};

        int[] dp = new int[n+1];
        dp[0] = 0;
        dp[1] = 1;
        for(int i=2; i<=n; i++){
            //偶数
            if(i % 2 == 0){
                dp[i] = dp[i/2];
            }
            //奇数
            else{
                dp[i] = dp[i-1] + 1;
            }
        }
        return dp;
    }
}
相关推荐
小厂永远得不到的男人3 分钟前
ioc 原理篇
java·后端
小厂永远得不到的男人3 分钟前
Aop 原理篇
java
屁股割了还要学12 分钟前
【数据结构入门】排序算法:插入排序
c语言·开发语言·数据结构·算法·青少年编程·排序算法
13 分钟前
JAVA-15 (2025.08.20学习记录)
java·开发语言·学习
whitepure22 分钟前
万字详解Java枚举
java·后端
用户83562907805122 分钟前
在 Java 中读取 Excel 文件
java·后端
农场主John23 分钟前
(栈)Leetcode155最小栈+739每日温度
windows·python·算法·leetcode·
qianmoq24 分钟前
第02章:创建Stream的N种方法:让数据流起来
java
Fireworkitte28 分钟前
Tomcat里catalina.sh详解
java
whitepure28 分钟前
万字详解Java注解
java·后端