leedcode 位1的数量

自己写的

复制代码
class Solution:
    def hammingWeight(self, n: int) -> int:
        # 将整数 n 转换为二进制字符串,去除前缀 '0b'
        n_str = bin(n)[2:]

        # 用于存储 '1' 的列表
        res_li = []

        # 遍历二进制字符串的每一位
        for i in n_str:
            # 如果当前位是 '1',则加入列表
            if int(i):
                res_li.append(i)

        # 返回 '1' 的个数(列表的长度)
        return len(res_li)
复制代码

位运算:使用n&=n-1

复制代码
class Solution:
    def hammingWeight(self, n: int) -> int:
        # 初始化计数器
        count = 0
        
        # 当 n 不为零时,执行循环
        while n:
            # 通过 n &= n - 1 操作,将 n 的最低位 '1' 置零
            n &= n - 1
            
            # 每置零一次,计数器加一
            count += 1
        
        # 返回 '1' 的个数
        return count
复制代码

 

posted @   Junior_bond  阅读(2)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示