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;
    }
}
相关推荐
范什么特西6 分钟前
idea创建一个普通的Maven项目运行javaweb
java·maven·intellij-idea
好家伙VCC12 分钟前
# 发散创新:用 Rust实现高性能物理引擎的底层架构设计与实战在游戏开发、虚拟仿真和机器人控
java·开发语言·python·rust·机器人
六道对穿肠13 分钟前
Java 直连 USB 打印机实战:从 JNI 崩溃到「拷贝即用」的架构演进
java
user_admin_god23 分钟前
OpenCode入门到入坑
java·人工智能·spring boot·语言模型
Maiko Star24 分钟前
Claude Code安装教程
java·chatgpt·claude code
Tina学编程28 分钟前
[HOT 100]今日一练------划分字母区间
算法·hot 100
RTC老炮29 分钟前
RaptorQ前向纠错算法架构分析
网络·算法·架构·webrtc
故事和你9129 分钟前
洛谷-数据结构1-1-线性表2
开发语言·数据结构·算法·动态规划·图论
m0_5557629034 分钟前
从原始信号到IQ图的数学公式推导
算法
靠沿36 分钟前
【递归、搜索与回溯算法】专题四——综合练习
算法·深度优先