定个小目标之刷LeetCode热题(41)

338. 比特位计数

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

今天看一下这道简单题,主要考查位运算,代码如下

java 复制代码
class Solution {
    public int[] countBits(int n) {
        int[] bits = new int[n + 1];
        int heightBit = 0;
        for (int i = 1; i <= n; i++) {
            if ((i & (i - 1)) == 0) {
                heightBit = i;
            }
            bits[i] = bits[i - heightBit] + 1;
        }
        return bits;
    }
}

题目链接:题单 - 力扣(LeetCode)全球极客挚爱的技术成长平台

相关推荐
求梦820几秒前
【力扣hot100题】反转链表(18)
算法·leetcode·职场和发展
NAGNIP13 分钟前
机器学习特征工程中的特征选择
算法·面试
l1t19 分钟前
DeepSeek辅助编写的利用位掩码填充唯一候选数方法求解数独SQL
数据库·sql·算法·postgresql
Z1Jxxx23 分钟前
反序数反序数
数据结构·c++·算法
副露のmagic24 分钟前
更弱智的算法学习 day25
python·学习·算法
求梦82024 分钟前
【力扣hot100题】移动零(1)
算法·leetcode·职场和发展
NAGNIP28 分钟前
机器学习中的数据预处理方法大全!
算法·面试
涛涛北京36 分钟前
Soft-Actor-Critic算法-连续环境
算法
vyuvyucd38 分钟前
C++排序算法全解析
java·数据结构·算法
胡萝卜不甜40 分钟前
算法宗门---迪杰斯特拉Dijkstra(最短路径算法)
算法