当前位置:网站首页>【每日一道LeetCode】——191. 位1的个数
【每日一道LeetCode】——191. 位1的个数
2022-07-30 18:27:00 【月亮嚼成星~】
作者简介:一名大一在校生
个人主页:月亮嚼成星~
个人WeChat:yx1552029968
系列专栏:每日一道LeetCode
每日一句: 决定一个人成就的,不是靠天,也不是靠运气,而是坚持和付出,是不停地做,重复的做,用心去做,当你真的努力了付出了,你会发现自己潜力无限!
目录
原题:位1的个数
编写一个函数,输入是一个无符号整数(以二进制串的形式),返回其二进制表达式中数字位数为 '1' 的个数(也被称为汉明重量)。
示例 1:
输入:00000000000000000000000000001011
输出:3
解释:输入的二进制串 00000000000000000000000000001011 中,共有三位为 '1'。
示例 2:
输入:00000000000000000000000010000000
输出:1
解释:输入的二进制串 00000000000000000000000010000000 中,共有一位为 '1'。
示例 3:
输入:11111111111111111111111111111101
输出:31
解释:输入的二进制串 11111111111111111111111111111101 中,共有 31 位为 '1'。
提示:这道题涉及到了二进制位运算和移位运算的知识,不知道的铁汁们可以看一下博主的这一篇文章,浅浅的介绍了相关知识,帮助我们来做题:【Java SE]位运算和移位运算注意事项
解题思路:
方法一:暴力移位求解
为了记录1的位数,我们需要设置一个计数器count并将其初始化为0;为了得出一个位置是否为1,要用按位与(&)1来进行操作,如果是1,结果就是1,不是1,结果为0。这只是一个位置的比较,考虑到有32位,所以我们运用位运算来实现每一位与1进行比较,循环后即可得到1的数。 为了便于理解,画了个第一次比较的图,后面的比较方法一样。
这道题当然会有更多优秀的解法,随着思路的开阔,我们将会想到更多好的解法!

代码执行:
public class Solution {
// you need to treat n as an unsigned value
public int hammingWeight(int n) {
int count=0;//计数器
for(int i=31;i>=0;i--){
if(((n>>i)&1)==1){
count++;
}
}
return count;
}
}
- 复杂度分析:时间复杂度
O(k),k=32。空间复杂度为O(1)
执行结果:

方法2:优化循环的过程
思路:巧用二进制公式x&(x-1)表示去掉二进制中最右边的第一个1,加速循环过程
代码执行:
public class Solution {
public int hammingWeight(int n) {
int ret = 0;
while (n != 0) {
n &= n - 1;
ret++;
}
return ret;
}
}
运行结果:
复杂度分析:时间复杂度为O(k),k为二进制中1的个数,最坏的情况下所有位都是1。空间复杂度是O(1)
总结:
每天都来刷一道LeetCode是多么幸福的一件事,各位,共勉!!
边栏推荐
- 【HMS core】【FAQ】Account Kit、MDM能力、push Kit典型问题合集6
- "Ruffian Heng Embedded Bimonthly" Issue 59
- Pagoda builds PHP adaptive lazy website navigation source code measurement
- 《痞子衡嵌入式半月刊》 第 59 期
- 一文读懂“语言模型”
- ROS 节点初始化步骤、topic/service创建及使用
- ctf.show_web5
- linux 下MySQL本地安装mysql - u root - p 无法登入
- 【HarmonyOS】【ARK UI】HarmonyOS ets语言怎么实现双击返回键退出
- 【Pointing to Offer】Pointing to Offer 22. The kth node from the bottom in the linked list
猜你喜欢
随机推荐
【剑指 Offe】剑指 Offer 18. 删除链表的节点
使用postman调接口报Content type ‘text/plain;charset=UTF-8‘ not supported
cocos creater 热更重启导致崩溃
CMake库搜索函数居然不搜索LD_LIBRARY_PATH
AI基础:图解Transformer
[Solved] The problem that Unity Hub fails to obtain a license or does not respond and cannot develop
ESP8266-Arduino programming example-HC-SR04 ultrasonic sensor driver
运营 23 年,昔日“国内第一大电商网站”黄了...
【Pointing to Offer】Pointing to Offer 18. Delete the node of the linked list
你好好想想,你真的需要配置中心吗?
微信小程序云开发 | 城市信息管理
千亿级、大规模:腾讯超大 Apache Pulsar 集群性能调优实践
沉浸式体验科大讯飞2022消博会“官方指定产品”
linux 下MySQL本地安装mysql - u root - p 无法登入
自然语言处理nltk
这玩意儿都能优化?果然是细节都在魔鬼里。
Application of time series database in the field of ship risk management
【剑指 Offer】剑指 Offer 22. 链表中倒数第k个节点
【HMS Core】【FAQ】运动健康、音频编辑、华为帐号服务 典型问题合集7
mysql的多实例

作者简介:
个人主页:
个人WeChat:
系列专栏:
每日一句: 








