Given an integer (signed 32 bits), write a function to check whether it is a power of 4.
Example:
Given num = 16, return true. Given num = 5, return false.
Follow up: Could you solve it without loops/recursion?
Credits:
Special thanks to @yukuairoy for adding this problem and creating all test cases.
class Solution {
public:
bool isPowerOfFour(int num) {
if(num<=0) return false;
if(num==4||num==1) return true;
if(num%4!=0) return false;
else return isPowerOfFour(num/4);
}
};
想用一句话,发现不行:
class Solution {
public:
bool isPowerOfFour(int num) {
return !(num&(num-1))&&num>0&&num%4==0;
}
};
和2的倍数不一样。
参考别人的代码发现可以这样搞:
一个数 num 如果是 4 的 N 次方必然也是 2 的 N 次方。所以可以先判断 num 是否是 2 的 N 次方。然后再将 2 的 N 次方中那些不是 4 的 N 次方的数去掉。因此就有了下面的代码。
bool isPowerOfFour(int num)
{
if(num <= 0) return false;
if(num & (num - 1)) return false; // 先判断是否是 2 的 N 次方
if(num & 0x55555555) return true; // 再将不是 4 的 N 次方的数字去掉
return false;
}