给定一个整数,编写一个函数来判断它是否是 2 的幂次方。
示例 1:
输入: 1
输出: true
解释: 20 = 1
示例 2:
输入: 16
输出: true
解释: 24 = 16
示例 3:
输入: 218
输出: false
我的代码:
class Solution {
public:
bool isPowerOfTwo(int n) {
if(n%2==1)
return true;
while(n>1)
{
if(n%2==1)
return false;
else
n/=2;
}
return true;
}
};
位运算:
class Solution:
def isPowerOfTwo(self, n: int) -> bool:
return n > 0 and n & n - 1 == 0
class Solution {
public:
bool isPowerOfTwo(int n) {
if (n>0)
return ((n&(n-1))==0);
else
return false;
}
};
最开始用2相除在进行判断,后来发现用位运算,二进制的数中2的幂则是只有一个1其他都为0的一串数