剑指 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 的幂

相关推荐
野生技术架构师7 小时前
一线大厂Java面试八股文全栈通关手册(含源码级详解)
java·开发语言·面试
史蒂芬_丁9 小时前
Qt, C++数据类型扩展问题
数据库·c++·qt
6Hzlia9 小时前
【Hot 100 刷题计划】 LeetCode 118. 杨辉三角 | C++ 动态规划题解
c++·leetcode·动态规划
三道渊10 小时前
C语言:文件I/O
c语言·开发语言·数据结构·c++
是有头发的程序猿11 小时前
用Open Claw接口做1688选品、价格监控、货源对比
开发语言·c++·人工智能
计算机安禾11 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
Zarek枫煜12 小时前
[特殊字符] C3语言:传承C之高效,突破C之局限
c语言·开发语言·c++·单片机·嵌入式硬件·物联网·算法
寻寻觅觅☆12 小时前
东华OJ-基础题-30-求最晚和最早日期(C++)
数据结构·c++·算法
Lee川12 小时前
🔍 React 面试官眼中的“秘密武器”:深度剖析 useRef
前端·react.js·面试
_Twink1e13 小时前
[算法竞赛]九、C++标准模板库STL常用容器大全
开发语言·c++