我是靠谱客的博主 外向老虎,最近开发中收集的这篇文章主要介绍2 的幂(C++),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

2 的幂

难度简单540收藏分享切换为英文接收动态反馈

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

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

示例 1:

输入: n = 1
输出: true
解释: 20 = 1

示例 2:

输入: n = 16
输出: true
解释: 24 = 16

示例 3:

输入: n = 3
输出: false

示例 4:

输入: n = 4
输出: true

示例 5:

输入: n = 5
输出: false

提示:

  • -231 <= n <= 231 - 1

我的代码:

class Solution {
public:
    bool isPowerOfTwo(int n) {
        // n - 1就是把n的二进制位的最右边的那个1去掉 如果这个时候去掉了最右边的那个1
        // 这个还是很妙的 如果n真的是2的幂的话 应该是这种形式 100000...
        // 这个数字和n-1的&一定是0
        return n > 0 && (n & (n - 1)) == 0;
    }
};

对应我的掘金文章

最后

以上就是外向老虎为你收集整理的2 的幂(C++)的全部内容,希望文章能够帮你解决2 的幂(C++)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(69)

评论列表共有 0 条评论

立即
投稿
返回
顶部