【Leetcode】231. 2的幂

给你一个整数 n,请你判断该整数是否是 2 的幂次方。如果是,返回 true;否则,返回 false

如果存在一个整数 x 使得 n == 2x ,则认为 n2 的幂次方。

示例 1:

输入:n = 1

输出:true

解释:20 = 1

示例 2:

输入:n = 16

输出:true

解释:24 = 16

示例 3:

输入:n = 3

输出:false

提示:

-231 <= n <= 231 - 1

  • 进阶 :你能够不使用循环 / 递归解决此问题吗?

AC:

cpp 复制代码
class Solution {
public:
    bool isPowerOfTwo(int n) {
        if(n <= 0)
            return false;
        // 2 的幂的二进制表示中只有一个 1,
        // 所以 n & (n - 1) 应该等于 0
        return (n & (n - 1)) == 0;
    }
};
  • 这是道很典型2的幂 判断 题型
  • 至于为何能够判断?

解释如下:

2 的幂的二进制表示里,只有一个 1

1 -> 0001

2 -> 0010

4 -> 0100

8 -> 1000

发生了什么?

n - 1 会把 n 最高位的那个 1 变成 0

并把该位右边的所有低位 0 变成 1

例如

bash 复制代码
n = 8 (1000)
n - 1 = 7 (0111)
n & (n - 1) = 1000 & 0111 = 0000

对于任意只有一个 1 的数,nn-1 在那个位置上一定互斥,所以 按位与为 0

为什么不是其它数?

如果 n 不是 2 的幂,例如 n = 6:

6 = 0110

5 = 0101

6 & 5 = 0100,不是 0

6 有两个 1n-1 只会清掉最右边的 1,剩下的高位 1 仍然在结果中。

∴ 这个表达式的逻辑

n > 0

n 只有一个 1 位

n & (n - 1) 结果就是 0

因此 (n & (n - 1)) == 0 能返回 true,表示 n2 的幂。


附上官方题解

相关推荐
JieE2129 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack2016 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树18 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
A小辣椒19 小时前
TShark:Wireshark CLI 功能
linux
A小辣椒1 天前
TShark:基础知识
linux
AlfredZhao1 天前
OCI 明明分配了 200G 系统盘,为什么 df 只看到 30G?
linux·oci
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像