leetcode191:位1的个数

package com.mxnet;

public class Solution191 {

    public static void main(String[] args) {

        System.out.println(1 << 5);

    }

    /**
     * 编写一个函数,输入是一个无符号整数(以二进制串的形式),
     * 返回其二进制表达式中数字位数为 '1' 的个数(也被称为汉明重量)
     * @param n
     * @return
     * 思路:
     * 1. 使用按位与  & 计算方式
     * 2. 数字每一位都与 2 ^ i按位与
     */
    public int hammingWeight(int n) {
        int num = 0;
        for (int i = 0; i < 32; i++) {
            if ((n & 1 << i) != 0){
                num++;
            }
        }
        return num;
    }
}
posted @   mx_info  阅读(14)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示