定个小目标之刷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)全球极客挚爱的技术成长平台

相关推荐
TracyCoder1237 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵
算法·leetcode·矩阵
u0109272719 小时前
C++中的策略模式变体
开发语言·c++·算法
2501_941837269 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析
算法·yolo
六义义10 小时前
java基础十二
java·数据结构·算法
四维碎片10 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs10 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
独自破碎E11 小时前
【优先级队列】主持人调度(二)
算法
weixin_4454766811 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
打工的小王11 小时前
LeetCode Hot100(一)二分查找
算法·leetcode·职场和发展
Swift社区11 小时前
LeetCode 385 迷你语法分析器
算法·leetcode·职场和发展