[191] Number of 1 Bits

本文介绍了一种计算整数二进制表示中1的个数(即Hamming权重)的方法,并提供了三种实现方案:字符串转换法、位操作法及高效位操作法。文中详细解释了每种方法的工作原理和注意事项。

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

1. 题目描述

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.
读题可真是废了大劲了,一开始没懂是什么意思,看了看Hamming weight的wiki,更晕了。后来一搜,原来是给定一个整数(被看做无符号整数),统计这个无符号整数的二进制表示中有多少个1。

2. 解题思路

第一种想法,最简单的想法,将这个int值直接转换为字符串,统计字符串中1的个数,如Code1,这个方法效率不太高。
第二种想法,通过位移操作,每次用过按位与看最后一位是否为1,如果是1,那么就统计加1。这种方法由于有符号数(pretend to be unsigned)的特性坑比较多。
第三种就是比较牛逼的了,一次移动好几位,最好使用32能整除的位数,比如2,4,8,16之类的,这样移动起来比较方便。

3. Code

// Code1:效率很低
public class Solution {
    // you need to treat n as an unsigned value
    public int hammingWeight(int n) {
        // 将数字转为二进制字符串
        String s = Integer.toBinaryString(n);
        int result = 0;
        for (int i = 0; i < s.length(); ++i)
        {
            // 如果字符串中有字符1
            if (s.charAt(i) == '1')
            {
                // 结果个数加1
                ++result;
            }
        }
        return result;
    }
}
public class Solution {
    // you need to treat n as an unsigned value
    public int hammingWeight(int n) {
        // 第一坑,约定的无符号数并不代表这个数大于1
        /*if (n <= 0)
        {
            return 0;
        }*/
        int result = 0;
        // 第二坑,MIN_VALUE的abs值是0,而本来的设定是移到0时退出,返回结果
        while(Math.abs(n) > 0 || n == Integer.MIN_VALUE)
        {
            if ((n & 1) == 1)
            {
                ++result;
            }
            // 第三坑,既然符号位也算到统计中,需要使用带符号右移的操作
            n >>>= 1;  // 带符号右移一位,符号位跟着一起向右移动
        }
        return result;
    }
}
    // 附上Math.abs(int value)
    public static int abs(int a) {
        return (a < 0) ? -a : a;
    }
// 最后附一个牛人发明的效率更高的方法
public class Solution {
    // you need to treat n as an unsigned value
    private static final int[] ARR = new int[]{0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4};
    public int hammingWeight(int n) {
        int result = 0;
        while(Math.abs(n) > 0 || n == Integer.MIN_VALUE)
        {
            result+=ARR[n & 0xF];
            n >>>= 4; // 一下子移动4位,效率变高,喜欢的话,可以填个2048的,这样计算个3次就够了:)
        }
        return result;
    }
}
<think>好的,我现在需要帮助用户了解和使用pypinyin。首先,用户可能对安装步骤不太清楚,所以应该先介绍如何安装。根据引用[1],安装PyPinyin可以通过pip命令,所以需要告诉用户执行`pip install pypinyin`。 接下来,用户可能想知道基本用法。引用[2]和[4]提到了`pinyin`和`lazy_pinyin`函数,以及拼音风格的设置。我需要解释这两个函数的区别,比如`pinyin`返回带声调的音节,而`lazy_pinyin`是无声调的,并且可能更简洁。同时,要提到如何通过`style`参数自定义拼音风格,比如首字母或带声调。 然后,用户可能遇到多音字的问题,引用[3]提到如何处理这种情况。需要举例说明如何启用多音字模式,使用`heteronym=True`参数,并给出例子,比如“重庆”会返回不同的拼音组合。 另外,引用[4]还提到了首字母的获取方法,使用`Style.FIRST_LETTER`风格,这也是用户可能需要的功能之一,应该包含在示例中。 用户可能希望看到实际的应用案例,比如将中文转换为拼音用于排序、生成用户名或处理多音字。这些案例能帮助用户理解的实际用途,同时展示不同函数和参数的效果。 最后,根据用户的问题,生成相关的问题,比如如何处理多音字、如何自定义拼音风格,以及是否有其他类似推荐。这些相关问题可以帮助用户进一步探索的功能和解决可能遇到的问题。 需要确保所有代码示例正确,使用正确的语法,并且符合用户的中文需求。同时,引用正确的来源,比如引用[1]到[4],并在回答末尾添加引用标识。检查是否有遗漏的步骤或功能,确保回答结构清晰,逐步引导用户安装、基本使用、处理多音字和实际应用。</think># PyPinyin使用指南 PyPinyin是一个功能强大的Python,用于将中文转换为拼音。以下是详细的使用方法: ## 1. 安装 ```bash pip install pypinyin ``` 建议使用虚拟环境安装[^1] ## 2. 基本使用 ### (1) 获取标准拼音 ```python import pypinyin # 带声调输出 print(pypinyin.pinyin('你好')) # [['nǐ'], ['hǎo']] # 无声调输出 print(pypinyin.lazy_pinyin('你好')) # ['ni', 'hao'] ``` ### (2) 自定义拼音风格 ```python from pypinyin import Style # 首字母风格 print(pypinyin.lazy_pinyin('中文', style=Style.FIRST_LETTER)) # ['z', 'w'] # 带数字声调 print(pypinyin.lazy_pinyin('重庆', style=Style.TONE2)) # ['cho2ng', 'qi4ng'] ``` ## 3. 多音字处理 ```python # 显示所有可能的读音 print(pypinyin.pinyin('重庆', heteronym=True)) # 输出: [['zhòng', 'chóng', 'tóng'], ['qìng']] ``` 通过设置`heteronym=True`参数可以获取多音字的所有可能读音[^3] ## 4. 实际应用案例 ### (1) 中文排序 ```python names = ['张三', '李四', '王五'] sorted_names = sorted(names, key=lambda x: pypinyin.lazy_pinyin(x)) # 结果: ['李四', '王五', '张三'] ``` ### (2) 用户名生成 ```python def generate_username(name): pinyin = pypinyin.lazy_pinyin(name, style=Style.FIRST_LETTER) return ''.join(pinyin) + '2024' print(generate_username('张三')) # zs2024 ``` ### (3) 多音字标注 ```python text = "银行行长说行业需要整改" for word, pinyins in zip(text, pypinyin.pinyin(text, heteronym=True)): print(f"{word}: {pinyins}") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值