【每日一道LeetCode】——191. 位1的个数

在这里插入图片描述

96fded2715d54a1a9dbf8d591b0f6cc6.png作者简介:一名大一在校生 

1dcdea841dc84e5daf2868d121ca7b4e.png个人主页:月亮嚼成星~

06594baba3894494a77f632d61a0a55d.png个人WeChat:yx1552029968

cf768df40706413e9fef3a992ed367c8.png系列专栏:每日一道LeetCode

39190fda869b4100bc23b9d7a235d91c.png每日一句: 决定一个人成就的,不是靠天,也不是靠运气,而是坚持和付出,是不停地做,重复的做,用心去做,当你真的努力了付出了,你会发现自己潜力无限! 

目录

原题:位1的个数

解题思路:

总结:


原题:位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是多么幸福的一件事,各位,共勉!!

  • 9
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

渴望力量的土狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值