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

相关推荐
Gyoku Mint24 分钟前
深度学习×第4卷:Pytorch实战——她第一次用张量去拟合你的轨迹
人工智能·pytorch·python·深度学习·神经网络·算法·聚类
葫三生1 小时前
如何评价《论三生原理》在科技界的地位?
人工智能·算法·机器学习·数学建模·量子计算
拓端研究室4 小时前
视频讲解:门槛效应模型Threshold Effect分析数字金融指数与消费结构数据
前端·算法
随缘而动,随遇而安6 小时前
第八十八篇 大数据中的递归算法:从俄罗斯套娃到分布式计算的奇妙之旅
大数据·数据结构·算法
IT古董6 小时前
【第二章:机器学习与神经网络概述】03.类算法理论与实践-(3)决策树分类器
神经网络·算法·机器学习
Alfred king9 小时前
面试150 生命游戏
leetcode·游戏·面试·数组
水木兰亭9 小时前
数据结构之——树及树的存储
数据结构·c++·学习·算法
June bug10 小时前
【软考中级·软件评测师】下午题·面向对象测试之架构考点全析:分层、分布式、微内核与事件驱动
经验分享·分布式·职场和发展·架构·学习方法·测试·软考
Jess0710 小时前
插入排序的简单介绍
数据结构·算法·排序算法
老一岁10 小时前
选择排序算法详解
数据结构·算法·排序算法