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

相关推荐
努力学习的小廉4 分钟前
【C++】 —— 笔试刷题day_29
开发语言·c++·算法
小羊在奋斗6 分钟前
【LeetCode 热题 100】搜索插入位置 / 搜索旋转排序数组 / 寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
meisongqing12 分钟前
【软件工程】符号执行与约束求解缺陷检测方法
人工智能·算法·软件工程·软件缺陷
莫叫石榴姐33 分钟前
如何为大模型编写优雅且高效的提示词?
人工智能·算法
Echo``2 小时前
1:OpenCV—图像基础
c++·图像处理·人工智能·opencv·算法·计算机视觉·视觉检测
COOCC12 小时前
激活函数全解析:定义、分类与 17 种常用函数详解
人工智能·深度学习·神经网络·算法·机器学习·计算机视觉·自然语言处理
林下清风~2 小时前
力扣hot100——347.前K个高频元素(cpp手撕堆)
算法·leetcode·职场和发展
小雅痞2 小时前
[Java][Leetcode middle] 238. 除自身以外数组的乘积
java·leetcode
进击的小白菜3 小时前
Java回溯算法解决非递减子序列问题(LeetCode 491)的深度解析
java·算法·leetcode
-一杯为品-4 小时前
【深度学习】#11 优化算法
人工智能·深度学习·算法