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;
    }
}
相关推荐
严文文-Chris几秒前
RAG关键技术要点详解
java·服务器·前端
一起养小猫2 分钟前
LeetCode100天Day5-最小长度子数组与三数之和
算法·leetcode·职场和发展
❀͜͡傀儡师4 分钟前
基于docker一键部署 x86的cpu_mem_hog 用于生成CPU和内存负载,用于服务器cpu和内存使用不达标的
java·服务器·docker
小龙报4 分钟前
【初阶数据结构】从 “数组升级” 到工程实现:动态顺序表实现框架的硬核拆解指南
c语言·数据结构·c++·算法·机器学习·信息与通信·visual studio
蜡笔大新7986 分钟前
IO流的认识(2)
java·ide·intellij-idea
多米Domi0119 分钟前
0x3f第九天复习(考研日)(10.57-14:00)
python·算法
廋到被风吹走16 分钟前
【Java】【JVM】OOM 原因、定位与解决方案
java·开发语言·jvm
byzh_rc17 分钟前
[模式识别-从入门到入土] 拓展-EM算法
算法·机器学习·概率论
努力学算法的蒟蒻20 分钟前
day41(12.22)——leetcode面试经典150
算法·leetcode·面试
苹果醋321 分钟前
vue + iview + vue-i18n中英翻译
java·运维·spring boot·mysql·nginx