首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >LeetCode笔记:191. Number of 1 Bits

LeetCode笔记:191. Number of 1 Bits

作者头像
Cloudox
发布2021-11-23 14:41:19
发布2021-11-23 14:41:19
2300
举报
文章被收录于专栏:月亮与二进制月亮与二进制

问题:

Write a function that takes an unsigned integer and returns the number of ’1' bits it has (also known as the Hamming weight). For example, the 32-bit integer ’11' has binary representation 00000000000000000000000000001011, so the function should return 3.

大意:

写一个函数,获取一个无符号整型数并返回它拥有的‘1’bits的个数(也称为Hamming weight)。 比如,32位整型数‘11’二进制表示为00000000000000000000000000001011,所以函数应该返回3。

思路:

题目的意思其实就是问一个无符号整型数的二进制形式中有多少个1。这里无符号的意思是没有负数都是正数,直接的思路就是将它转换成二进制后一个个数里面1的个数,很简单。

代码(Java):

代码语言:javascript
复制
public class Solution {
    // you need to treat n as an unsigned value
    public int hammingWeight(int n) {
        String binaryStr = Integer.toBinaryString(n);
        int result = 0;
        for (int i = 0; i < binaryStr.length(); i++) {
            if (binaryStr.charAt(i) == '1') result++;
        }
        return result;
    }
}

他山之石:

代码语言:javascript
复制
public static int hammingWeight(int n) {
    int ones = 0;
        while(n!=0) {
            ones = ones + (n & 1);
            n = n>>>1;
        }
        return ones;
}

按照我的方法做完提交后虽然过了,也只有4ms,但是在结果统计中依然算慢的了,应该是转换成二进制那一步耗时了,然后一般数字都会有很多零,而我都会一个个判断一次,其实就不必要了。看了看Discuss中的好方法,确实挺好,直接让n和1去按位与,如果n的最后一位是1就会结果加一,然后将n右移一位继续判断,这里注意用到的右移运算发是三个箭头“>>>”,这是因为这是无符号数的右移运算符,有符号数就是两个箭头“>>”。同时循环的结束条件是n为0,这就免去了很多多余的判断,确实很赞。

合集:https://github.com/Cloudox/LeetCode-Record

查看作者首页

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017/11/21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题:
  • 大意:
  • 思路:
  • 代码(Java):
  • 他山之石:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档