【Python3】【力扣题】338. 比特位计数

【力扣题】题目描述:

题解:从0到n的整数,逐一统计二进制中1的个数,记录在一个新列表中。

【Python3】代码:

1、解题思路:Python函数。

知识点:bin(...):转为二进制字符串,即"0bxxx"。

字符串**.**count(...):统计字符串中某字符出现的次数。

列表**.**append(...):往列表尾部添加元素。

列表推导式:用简洁的方式创建列表。即 [ 对元素的简单操作 for 变量 in 可迭代对象 ]

python 复制代码
class Solution:
    def countBits(self, n: int) -> List[int]:
        res = [bin(i)[2:].count("1") for i in range(n+1)]
        return res
        #相当于
        res = []
        for i in range(n+1):
            res.append(bin(i)[2:].count("1"))
        return res

2、解题思路:Brian Kernighan算法。

每次将整数的二进制最低位的1消除为0,直到整数变为0。消除多少次则二进制中有多少个1。

num &= (num-1) 即 num = num & (num-1) 。

相当于将二进制最低位的1消除为0。若num为2的整数幂,则num&(num-1)=0。

例如:num=5(二进制101),num-1=4(二进制100),num&(num-1)=101&100=100(即将101的最低位的1消除为0)。

python 复制代码
class Solution:
    def countBits(self, n: int) -> List[int]:
        res = []
        for i in range(n+1):
            cou = 0
            while i > 0:
                i &= (i-1)
                cou += 1
            res.append(cou)
        return res
        # 或者
        def count_one(num):
            cou = 0
            while num > 0:
                num &= (num-1)
                cou += 1
            return cou  
        res = [count_one(i) for i in range(n+1)]
        return res

3、解题思路:动态规划。

将一个问题拆分成多个子问题,解决子问题并记录子问题的结果减少重复计算,最终整个问题解决。

(3-1)若num是2的整数幂,num中只有最高位有1,则记录num。

若num不是2的整数幂,则num的二进制 比 去除最高位之后的二进制 多一个1。

例如:5(二进制101),去除最高位之后的二进制01(其个数已统计过为1),则5的二进制中1的个数为1+1=2个。

python 复制代码
class Solution:
    def countBits(self, n: int) -> List[int]:
        # 动态规划--最高有效位
        res = [0]
        high = 0                    # 记录最高有效位即二进制中只有最高位有一个1
        for i in range(1,n+1):
            if i & (i-1) == 0:
                high = i
            res.append(res[i-high] + 1)
        return res

(3-2)将二进制右移一位,去除最低位之后的二进制中1的个数已统计过;被去除的最低位若为1则结果中再加1。

例如:5(二进制101),右移一位之后的二进制10(其个数已统计过为1),被去除的最低位为1则5的二进制中1的个数为1+1=2个。

知识点:num >> 1:将num二进制右移一位。

i & 1:将num与1进行二进制与运算。

python 复制代码
class Solution:
    def countBits(self, n: int) -> List[int]:
        # 动态规划-最低有效位
        res = [0]
        for i in range(1,n+1):
            res.append(res[i >> 1] + (i & 1))
        return res

(3-3)num&(num-1)消除num最低位的1,则num 比 消除最低位1之后 多一个1。

例如:num=5(二进制101),num-1=4(二进制100),num&(num-1)=101&100=100,二进制100其个数已统计过为1,则5的二进制中1的个数为1+1=2个。

python 复制代码
class Solution:
    def countBits(self, n: int) -> List[int]:
        # 动态规划--最低设置位
        res = [0]
        for i in range(1,n+1):
            res.append(res[i & (i-1)] + 1)
        return res
相关推荐
AI_56786 小时前
Selenium+Python可通过 元素定位→操作模拟→断言验证 三步实现Web自动化测试
服务器·人工智能·python
蒜香拿铁6 小时前
【第三章】python算数运算符
python
如何原谅奋力过但无声7 小时前
【力扣-Python-滑动窗口经典题】567.字符串的排列 | 424.替换后的最长重复字符 | 76.最小覆盖子串
算法·leetcode
52Hz1188 小时前
力扣73.矩阵置零、54.螺旋矩阵、48.旋转图像
python·算法·leetcode·矩阵
iAkuya9 小时前
(leetcode)力扣100 二叉搜索树种第K小的元素(中序遍历||记录子树的节点数)
算法·leetcode·职场和发展
weixin_462446239 小时前
Python 使用 openpyxl 从 URL 读取 Excel 并获取 Sheet 及单元格样式信息
python·excel·openpyxl
毕设源码-钟学长9 小时前
【开题答辩全过程】以 基于Python的健康食谱规划系统的设计与实现为例,包含答辩的问题和答案
开发语言·python
Remember_99310 小时前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode
百***787510 小时前
Grok-4.1技术深度解析:双版本架构突破与Python API快速集成指南
大数据·python·架构
2501_9421917711 小时前
基于YOLO11-HSFPN的数字检测与识别模型实现详解
python