LeetCode、338. 比特位计数【简单,位运算】

文章目录

前言

博主介绍:✌目前全网粉丝2W+,csdn博客专家、Java领域优质创作者,博客之星、阿里云平台优质作者、专注于Java后端技术领域。

涵盖技术内容:Java后端、算法、分布式微服务、中间件、前端、运维、ROS等。

博主所有博客文件目录索引:博客目录索引(持续更新)

视频平台:b站-Coder长路


LeetCode、338. 比特位计数【中等,位运算】

题目链接与分类

题目链接:LeetCode、338. 比特位计数

分类:基础算法/位运算


思路

位运算移位处理

思路:暴力,来对所有数字的二进制位来进行模拟计算。

复杂度分析:时间复杂度O(n.logn);空间复杂度O(n)

java 复制代码
class Solution {

    //10万数据量
    public int[] countBits(int n) {
        int[] res = new int[n + 1];
        for (int i = 0; i <= n; i ++) {
            int count = 0;
            int num = i;
            while (num != 0) {
                if (num % 2 == 1) count ++;
                num = num >> 1;
            }
            res[i] = count;
        }
        return res;
    }
}

前缀思想实现

思路:二叉树来保存1-n,左子树使用0、右子树使用1,左边表示+1,右边表示x2+1。

复杂度分析:时间复杂度O(n);空间复杂度O(n)

java 复制代码
class Solution {
    // 主函数,计算 0 到 n 的每个数字的二进制表示中包含的 1 的个数
    public int[] countBits(int n) {
        int[] res = new int[n + 1]; // 初始化结果数组
        // 从数字1开始进行深度优先搜索
        dfs(1, n, 1, res);
        return res;
    }

    // 深度优先搜索函数
    private void dfs(int num, int max, int cnt, int[] res) {
        if (num > max) { // 如果当前数字大于给定的最大值,结束递归
            return;
        }
        res[num] = cnt; // 更新结果数组,记录当前数字的二进制表示中包含的1的个数
        // 递归调用左子树和右子树
        dfs(num << 1, max, cnt, res); // 左子树,1的个数不变
        dfs((num << 1) + 1, max, cnt + 1, res); // 右子树,1的个数加1
    }
}

资料获取

大家点赞、收藏、关注、评论啦~

精彩专栏推荐订阅:在下方专栏👇🏻

更多博客与资料可查看👇🏻获取联系方式👇🏻,🍅文末获取开发资源及更多资源博客获取🍅


整理者:长路 时间:2024.2.13

相关推荐
Lenyiin几秒前
01.02、判定是否互为字符重排
算法·leetcode
鸽鸽程序猿16 分钟前
【算法】【优选算法】宽搜(BFS)中队列的使用
算法·宽度优先·队列
Jackey_Song_Odd16 分钟前
C语言 单向链表反转问题
c语言·数据结构·算法·链表
Watermelo61720 分钟前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
乐之者v25 分钟前
leetCode43.字符串相乘
java·数据结构·算法
A懿轩A1 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
古希腊掌管学习的神1 小时前
[搜广推]王树森推荐系统——矩阵补充&最近邻查找
python·算法·机器学习·矩阵
云边有个稻草人1 小时前
【优选算法】—复写零(双指针算法)
笔记·算法·双指针算法
半盏茶香1 小时前
在21世纪的我用C语言探寻世界本质 ——编译和链接(编译环境和运行环境)
c语言·开发语言·c++·算法
忘梓.2 小时前
解锁动态规划的奥秘:从零到精通的创新思维解析(3)
算法·动态规划