3 汉明权重

本文探讨了高效计算整数二进制表示中1的个数的方法。介绍了两种核心策略:一是利用二进制位运算,通过位与操作结合右移实现;二是采用高中学过的二进制计算原理,循环除以2并统计余数。文章旨在提供解决此类问题的实用技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

即判断整数中有几个1
直接二进制展开的话,对于较大数字无法处理。因此要讲究下技巧
两种方式,1是二进制运算,位与、左右移…
每次n&1,1即000000…1,所以n&1返回的值要么是1 要么是0
然后处理后的“n”,右移一位,继续判断
最后计数
2 高中学的二进制计算方法–除以2,最后统计所有余数即为二进制
所以循环除以2,分两种情况:余1、整除,来讨论
代码看我勤劳程度补充

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值