剑指 Offer(第2版)面试题 15:二进制中1的个数

剑指 Offer(第2版)面试题 15:二进制中1的个数

  • [剑指 Offer(第2版)面试题 15:二进制中1的个数](#剑指 Offer(第2版)面试题 15:二进制中1的个数)

剑指 Offer(第2版)面试题 15:二进制中1的个数

题目来源:26. 二进制中1的个数

此题与 Leetcode191. 位1的个数 一致。

解法1:位运算

循环检查给定整数 n 的二进制位的每一位是否为 1。

当检查第 i 位时,我们可以让 n 与 2i 进行与(&)运算,当且仅当 n 的第 i 位为 1 时,运算结果不为 0。

设置一个计数器,遍历一次即可得到位 1 的个数。

注意:1 << i 必须是 uint32_t 的。

代码:

c 复制代码
class Solution
{
public:
	int NumberOf1(int n)
	{
		int count = 0;
		for (int i = 0; i < 32; i++)
			if (n & (uint32_t)1 << i)
				count++;
		return count;
	}
};

复杂度分析:

时间复杂度:O(k),其中 k = 32,是 int 的位数。

空间复杂度:O(1)。

解法2:n & (n - 1)

随便一个 n:

那么 n - 1 会发生什么:对于上面随便给的一个 n,减去 1,但是低 2 位都是 0,减 1 必然需要借位,那何时结束呢?答案就是遇到 1 的时候。如果第一步骤中给的 n 末尾为 1,那么就直接在低位就结束了,也符合遇到 1 就停止的规则。

总结而言,n - 1 操作:

  1. 无论是借位,还是减 1,遇到 1 就停止;

  2. 从低位到高位,一直到 1,每一位都发生了反转。

n & (n - 1):将 n 最低位的一个 1 变成 0。

于是,要求一个数 n 中二进制 1 的个数,我们可以不断地对 n 进行 n = n & (n - 1) 操作,每进行一次,n 中最低位的 1 就会变成 0,直到 n 变成 0 为止,操作次数就是 n 中二进制 1 的个数。

代码:

c 复制代码
class Solution
{
public:
	int NumberOf1(int n)
	{
		int count = 0;
		while (n)
		{
			n = n & (n - 1);
			count++;
		}
		return count;
	}
};

复杂度分析:

时间复杂度:O(log n)。

空间复杂度:O(1)。

相关题目

LeetCode 231. 2 的幂

相关推荐
CCPC不拿奖不改名2 小时前
SQL基础(SQL小白教程):MySQL语句+环境一键搭建+面试习题
数据库·sql·计算机网络·mysql·oracle·面试·职场和发展
Dream it possible!3 小时前
LeetCode 面试经典 150_二分查找_在排序数组中查找元素的第一个和最后一个位置(115_34_C++_中等)
c++·leetcode·面试
月光下的麦克4 小时前
如何查案动态库版本
linux·运维·c++
小六子成长记4 小时前
【C++】:搜索二叉树的模拟实现
数据结构·c++·算法
汉克老师4 小时前
GESP2025年9月认证C++二级真题与解析(编程题1(优美的数字))
c++·算法·整除·枚举算法·求余·拆数
carver w5 小时前
MFC入门教程 最简版
c++·mfc
王老师青少年编程5 小时前
信奥赛C++提高组csp-s之倍增算法
c++·csp·信奥赛·csp-s·提高组·倍增算法·rmq
低频电磁之道5 小时前
编译C++的几种方式(MSVC编译器)
开发语言·c++
Zsy_0510035 小时前
【C++】类和对象(一)
开发语言·c++
是娇娇公主~6 小时前
工厂模式详细讲解
数据库·c++