Problem
Explain what the following code does: ((n & (n-1)) == 0).
Solution
When we have A & B == 0, it means that A and B have no common 1s, i.e. any two bits at the same positions of A and B are either different from each other, or two 0s.
It works because a binary power of two is of the form 1000…000 and subtracting one will give you 111…111. Then, when you AND those together, you get zero, such as with:
1000 0000 0000 0000
& 111 1111 1111 1111
==== ==== ==== ====
= 0000 0000 0000 0000
Any non-power-of-two input value will not give you zero when you perform that operation. For example, let’s try all the 3-bit combinations:
n n-1 n n-1 n&(n-1)
--- --- --- --- -------
0 -1 000 111 000 *
1 0 001 000 000 *
2 1 010 001 000 *
3 2 011 010 010
4 3 100 011 000 *
5 4 101 100 100
6 5 110 101 100
7 6 111 110 110
This can be used in Power of Two.