【LeetCode75】第六十七题 比特位计数

目录

题目:

示例:

分析:

代码:


题目:

示例:

分析:

题目给我们一个整数n,要我们返回一个长度为n+1的数组,数组的第 i 位元素是 整数 i 的二进制数拥有的1的数目。例如 10 的二进制是 1010,所以10拥有的1的数目是2。

那么我们直接从0遍历到n+1,再单独算出这个数拥有的1的数目就可以了。

第一种方法就是C++有内置一个函数,直接统计你这个数的二进制有多少个1,直接使用这个函数就可以得出来:

cpp 复制代码
__builtin_popcount(i)

第二种方法就是我们直接手算。我们可以从一个数的二进制的右边第一位开始统计1的数目。如果一个数余2等于1,那么它的右边第一位就是1。

所以我们可以反复对这个数余2再除2,直到这个数变成了0,那么我们也就统计出了1的数目。

代码:

cpp 复制代码
class Solution {
public:
    //手动计算每个数的二进制有多少1
    vector<int> countBits(int n) {
        vector<int>res(n+1,0);
        int temp=0;
        for(int i=0;i<=n;i++){
            temp=i;
            while(temp){
                //可以写成 res[i]+=temp&0x1;temp>>=1;
                res[i]+=temp%2;
                temp/=2;
            }
        }
        return res;
    }
    
    //使用内置函数 
    vector<int> countBits(int n) {
        vector<int>res(n+1,0);
        for(int i=0;i<=n;i++){
            res[i]=__builtin_popcount(i);
        }
        return res;
    }
};
相关推荐
楼田莉子4 小时前
Linux网络:IP协议
linux·服务器·网络·c++·学习·tcp/ip
wuminyu4 小时前
专家视角看JVM_StartThread
java·linux·c语言·jvm·c++
敲上瘾4 小时前
高并发内存池(三):PageCache(页缓存)的实现
linux·c++·缓存·高并发内存池·池化技术
XY_墨莲伊5 小时前
【实战项目】基于B/S结构Flask+Folium技术的出租车轨迹可视化分析系统(文末含完整源代码)
开发语言·后端·python·算法·机器学习·flask
爱吃桃子的ICer5 小时前
m1_pcie
数据结构
小雅痞5 小时前
[Java][Leetcode simple] 1. 两数之和
java·算法·leetcode
somi75 小时前
ARM-驱动-09-LCD FrameBuffer
arm开发·驱动开发·算法·自用
乐迪信息5 小时前
乐迪信息:智慧港口AI防爆摄像机实现船舶违规靠岸自动抓拍
大数据·人工智能·算法·安全·目标跟踪
winxp-pic5 小时前
图片校正软件 操作说明及算法介绍
算法
wayz115 小时前
Day 6 编程实战:决策树与过拟合分析
算法·决策树·机器学习