(n&(n-1))==0 和 n&(n-1)==0 在C++中做什么?
What do (n&(n-1))==0 and n&(n-1)==0 do in C++?
(n&(n-1))==0
和n&(n-1)==0
在C++中做什么(n
是一个整数)?
if ((n&(n-1))==0)
{
// do something
}
if (n&(n-1)==0)
{
// do something
}
他们应该测试数字n
是否是 2 的幂(尽管第二个没有这样做,如评论中所述)。它基于一个简单的观察,即在二进制表示中,2 的幂是唯一一个位设置为1
的数字。如果你从这个数字中减去1
,你会得到一个1
s的序列。
示例(正面):
n = 32
比二进制表示
n = 100000
然后 n - 1 = 011111 所以如果你拿n - 1 & n
你会得到0
.
示例(负数):
n = 6
比二进制表示
n = 110
现在
n - 1 = 101
所以((n - 1) & n) == 100 > 0
.
请注意,正如@harold在他的评论中提到的,0
也将通过此测试。
(n & (n - 1)) == 0
:
n & (n - 1)
取消设置n
in 二进制的下限设置位:XXX10000
->XXX00000
所以(n & (n - 1)) == 0
0
和2
的所有权力.
n & (n - 1) == 0
:
n & (n - 1) == 0
等效于n & ((n - 1) == 0)
(由于运算符的优先级),因此n == 1
。
正如卢卡斯所说,
它检查数字 n 是否是 2 的幂。
解释:-
如果 n = 3 或任何其他不是 2 幂
的数字 (n =3,所以 (n-1) = 2)
3 :- 0000 0011 2 :- 0000 0010
比 AND 操作 :- 0000 0010
如果 n = 2 或任何其他 2 的幂数
(n =2 所以 (n-1) = 1) 2 :- 0000 0010 1 :- 0000 0001
比 和 操作 :- 0000 0000
因此,如果数字是 2 的幂,则始终返回 0。
它用于检查 2 的幂,如下所示:
bool isPowerOfTwo(int n) {
return!(n&n-1)*n>0;
}
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 警告处理为错误这里有什么问题
- 什么时候调用组成单元对象的析构函数
- #定义c-预处理器常量..我做错了什么
- 努力将整数转换为链表。不知道我在这里做错了什么
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 什么时候在C++中返回常量引用是个好主意
- 当在同一名称空间中有两个具有相同签名的函数时,会发生什么
- C++避免重复声明的语法是什么
- c++库的公共头文件中应该包含什么
- 问题:什么是QAbstractItemView::NoEditTriggers的反面
- 有什么方法可以遍历结构吗
- 当类在C++中定义时,有什么方法可以"register"类吗?
- ifstream什么都没读
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- 我应该使用什么来代替void作为变体中的替代类型之一
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用