检查所有位是否为1的最佳方法是什么?

Kev*_*vin 2 python bit-manipulation bit python-2.7

我认为这很容易因为〜,但是〜只返回2 ^ x而不是0的负值.

sam*_*gak 7

您可以修改标准bithack以检查数字是2的幂(数字1的幂小于2的全部是1),特殊情况检查为零:

def allOnes(n):
    return ((n+1) & n == 0) and (n!=0)

print allOnes(255)
print allOnes(158)
print allOnes(0)
print allOnes(-1)
print allOnes(-2)
Run Code Online (Sandbox Code Playgroud)

输出:

True
False
False
True
False
Run Code Online (Sandbox Code Playgroud)

  • 这对于“1”、“3”、“7”、“15”等返回 true,如果 OP 考虑特定的 C 整数大小,这可能是意想不到的。 (3认同)