c++面试题(2)-----计算一个数字的二进制数中1的个数

  • 操作系统:ubuntu22.04
  • IDE:Visual Studio Code
  • 编程语言:C++11

题目描述:

请实现一个函数 int NumberOf1(int n),输入一个整数(可能为负数),输出该数二进制表示中 1 的个数。例如:

复制代码
把 9 表示成二进制是 1001,有 2 个 1;
把 -1 表示成二进制在补码形式下全是 1(32位系统下是 32 个 1)。

示例

bash 复制代码
输入: n = 9
输出: 2

输入: n = -1
输出: 32

解题思路

这个问题主要考察的是对 二进制和位运算的理解,以及如何处理 负数(补码表示)。

以下是几种常见解法:

方法一:逐位与操作(推荐)

cpp 复制代码
int NumberOf1(int n)
{
    int count = 0;
    while (n != 0)
    {
        ++count;
        n = n & (n - 1); // 消除最右边的一个 1
    }
    return count;
}

优点:

  • 不需要考虑正负;
  • 效率高,循环次数等于 1 的个数;
  • 利用了 n & (n - 1) 特性:每次消去一个 1。

方法二:右移判断每一位是否为 1

cpp 复制代码
int NumberOf1(int n) 
{
    int count = 0;
    unsigned int flag = 1; // 使用无符号数来避免右移时出错
    while (flag != 0)
    {
        if (n & flag)
            ++count;
        flag <<= 1;
    }
    return count;
}

说明:

  • 循环 32 次(32位整数);
  • 每次用 flag 来测试某一位是否为 1;
  • 对于负数也能正确处理(因为使用了无符号变量);

方法三:使用 C++ 内建函数(C++20 起)

如果你使用的是 C++20 或更高版本,可以使用标准库提供的函数:

cpp 复制代码
#include <bit>
int NumberOf1(int n) {
    return std::popcount(static_cast<unsigned int>(n));
}

说明:

  • std::popcount() 返回一个数中 1 的数量;
  • 需要将 int 强转为 unsigned int 来保证行为一致。

示例代码

cpp 复制代码
#include <iostream>

using namespace std;

class Solution {
public:
    int NumberOf1( int n )
    {
        int count = 0;
        while ( n != 0 )
        {
            ++count;
            n = n & ( n - 1 );  // 消除最右边的 1
        }
        return count;
    }
};

int main()
{
    Solution solution;
    cout << "9 中 1 的个数:" << solution.NumberOf1( 9 ) << endl;    // 输出 2
    cout << "-1 中 1 的个数:" << solution.NumberOf1( -1 ) << endl;  // 输出 32
    return 0;
}

运行结果

bash 复制代码
9 中 1 的个数:2
-1 中 1 的个数:32
相关推荐
数据皮皮侠9 分钟前
2285 上市公司组织衰退程度【Dec】2010-2024
大数据·人工智能·算法·制造
daxi15011 分钟前
C语言从入门到进阶——第17讲:字符串函数
c语言·开发语言·算法·蓝桥杯
967712 分钟前
C++ 内存管理的核心——RAII 机制。两种锁 lock_guard, unique_lock
java·jvm·c++
wljy114 分钟前
第十四届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组(个人见解,已完结)
c语言·c++·算法·蓝桥杯
CoderCodingNo17 分钟前
【GESP】C++八级考试大纲知识点梳理 (7) 算法的时间和空间效率分析
开发语言·c++·算法
程序员zgh17 分钟前
C++ 环形队列 从原理到实例演示
c语言·开发语言·数据结构·c++·学习
誰能久伴不乏21 分钟前
从数字世界到物理引擎:用 PWM 撕开 0 和 1 的结界
linux·arm开发·c++·qt
青瓷程序设计22 分钟前
基于YOLO的安全帽佩戴检测系统~Python+模型训练+2026原创+YOLO算法
python·算法·yolo
Trouvaille ~22 分钟前
【优选算法篇】拓扑排序——逻辑先后与任务依赖的终极拆解
数据结构·c++·算法·leetcode·青少年编程·蓝桥杯·拓扑学
T1an-125 分钟前
博乐科技笔试题
科技·算法