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
相关推荐
写代码的小球18 分钟前
求模运算符c
算法
tan180°3 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
大千AI助手4 小时前
DTW模版匹配:弹性对齐的时间序列相似度度量算法
人工智能·算法·机器学习·数据挖掘·模版匹配·dtw模版匹配
彭祥.5 小时前
Jetson边缘计算主板:Ubuntu 环境配置 CUDA 与 cudNN 推理环境 + OpenCV 与 C++ 进行目标分类
c++·opencv·分类
lzb_kkk5 小时前
【C++】C++四种类型转换操作符详解
开发语言·c++·windows·1024程序员节
YuTaoShao5 小时前
【LeetCode 热题 100】48. 旋转图像——转置+水平翻转
java·算法·leetcode·职场和发展
生态遥感监测笔记5 小时前
GEE利用已有土地利用数据选取样本点并进行分类
人工智能·算法·机器学习·分类·数据挖掘
Tony沈哲6 小时前
macOS 上为 Compose Desktop 构建跨架构图像处理 dylib:OpenCV + libraw + libheif 实践指南
opencv·算法
刘海东刘海东6 小时前
结构型智能科技的关键可行性——信息型智能向结构型智能的转变(修改提纲)
人工智能·算法·机器学习