描述
Given an integer, write a function to determine if it is a power of two.
分析
如果是power of two, 则2进制表达中,有且仅有一个1. 可以通过移位来数1的个数, 这里用了一个巧妙的办法, 即判断 N & (N-1) 是否为0.
代码
class Solution {
public:
bool isPowerOfTwo(int n) {
return n > 0 && ((n & (n -1)) == 0);
}
};

本文介绍了一种高效的方法来确定一个给定的整数是否为2的幂次。通过使用位操作,我们可以检查该整数的二进制表示中是否只有一个1,这是判断一个数是否为2的幂次的关键。
544

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



