一起学算法-231. 2 的幂

作者: 小杨同学97 | 来源:发表于2021-06-11 22:01 被阅读0次

一、题目

LeetCode-231. 2 的幂
链接:https://leetcode-cn.com/problems/power-of-two/

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

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

示例 1:
输入:n = 1
输出:true
解释:2^0 = 1

示例 2:
输入:n = 16
输出:true
解释:2^4 = 16

示例 3:
输入:n = 3
输出:false

示例 4:
输入:n = 4
输出:true

提示:
-2^31 <= n <= 2^31 - 1

二、解题思路

如果n = 2^x且 x为自然数(即 n为 2 的幂),则一定满足以下条件:

  1. 恒有 n & (n - 1) == 0,因为n 二进制最高位为 1,其余所有位为 0;
    n - 1二进制最高位为 0,其余所有位为 1;
  2. 一定满足 n > 0。

因此,通过 n > 0 且 n & (n - 1) == 0 即可判定是否满足 n = 2^x。

2^x n n-1 n&(n-1)
2^0 0001 0000 (0001) & (0000) == 0
2^1 0010 0001 (0010) & (0001) == 0
2^2 0100 0011 (0100) & (0011) == 0
2^3 1000 0111 (1000) & (0111) == 0

三、实现过程

c++

class Solution {
public:
    bool isPowerOfTwo(int n) {
        return n > 0 && (n & (n - 1)) == 0;
    }
};

PHP

class Solution {

    /**
     * @param Integer $n
     * @return Boolean
     */
    function isPowerOfTwo($n) {
        return $n > 0 && ($n & ($n - 1)) == 0;
    }
}

JavaScript

/**
 * @param {number} n
 * @return {boolean}
 */
var isPowerOfTwo = function(n) {
        return n > 0 && (n & (n - 1)) == 0;
};

四、小结

  1. 时间复杂度:O(1)
  2. 空间复杂度:O(1)

相关文章

  • 一起学算法-231. 2 的幂

    一、题目 LeetCode-231. 2 的幂链接:https://leetcode-cn.com/problem...

  • 「算法」231. 2 的幂

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

  • LeetCode 231-240

    231. 2的幂[https://leetcode-cn.com/problems/power-of-two/] ...

  • Leecode 位运算

    231. 2的幂[https://leetcode-cn.com/problems/power-of-two/] ...

  • LeetCode刷题 231. 2的幂

    231. 2的幂 题目 给定一个整数,编写一个函数来判断它是否是 2 的幂次方。 示例1: 示例 2: 示例 3:...

  • [LeetCode]231-2的幂

    231. 2的幂给定一个整数,编写一个函数来判断它是否是 2 的幂次方。示例:输入: 1 -> 输出: true输...

  • LeetCode 231 .2的幂(Power of Two)

    231. 2的幂 给定一个整数,编写一个函数来判断它是否是 2 的幂次方。 示例 1: 示例 2: 示例 3: P...

  • 231. 2的幂

    给定一个整数,编写一个函数来判断它是否是 2 的幂次方。 示例 1: 输入: 1输出: true解释: 20 = ...

  • 231. 2的幂

    给定一个整数,编写一个函数来判断它是否是 2 的幂次方。示例 1:输入: 1输出: true解释: 20 = 1示...

  • 231. 2的幂

    给定一个整数,编写一个函数来判断它是否是 2 的幂次方。 示例 1: 输入: 1输出: true解释: 20 = ...

网友评论

    本文标题:一起学算法-231. 2 的幂

    本文链接:https://www.haomeiwen.com/subject/fmzveltx.html