地址:
力扣
https://leetcode-cn.com/problems/power-of-four/
题目:
给定一个整数,写一个函数来判断它是否是 4 的幂次方。如果是,返回 true ;否则,返回 false 。
整数 n 是 4 的幂次方需满足:存在整数 x 使得 n == 4x
示例 1:
| 输入:n = 16 输出:true |
示例 2:
| 输入:n = 5 输出:false |
示例 3:
| 输入:n = 1 输出:true |
提示:
| -231 <= n <= 231 - 1 |
进阶:你能不使用循环或者递归来完成本题吗?
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/power-of-four
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
思路:
雷同 231. 2 的幂
需要注意的是遍历有溢出风险,所以需要计算最大循环次数
方法一、遍历
class Solution {
public:
bool isPowerOfFour(int n) {
int i;
unsigned int num=1; /*unsinged int: 0~4294967295*/
if(n <= 0)
return false;
if(n==1)
return true;
for(i=0; i<15; i++)
{
num *= 4; /* 4^15=1073741824, 4^16 > unsigned int rang*/
if(n == num)
return true;
}
return false;
}
};
方法二、位运算
1. 4^n 一定是 2^n
2. 2^n 不一定是 4^n
3. n为偶数时 2^n %3 == 1; 即 4^n %3 == 1
n 为奇数时 2^n %3 == 2
bool isPowerOfFour(int n){
return ( n > 0 && ( ( n & (n-1) ) == 0 ) && n%3 == 1);
}

639

被折叠的 条评论
为什么被折叠?



