Check if an integer is a power of 2

suggest change

The n & (n - 1) trick is also useful to determine if an integer is a power of 2:

bool power_of_2 = n && !(n & (n - 1));

Note that without the first part of the check (n &&), 0 is incorrectly considered a power of 2.

Feedback about page:

Feedback:
Optional: your email if you want me to get back to you:


Bit manipulation:
* Check if an integer is a power of 2

Table Of Contents
6 Bit manipulation
8 Arrays
11 Loops
39 Streams
51 Unions
56 Lambdas
60 SFINAE
62 RAII
67 Sorting
84 RTTI
87 Scopes
104 Profiling
107 Recursion
117 Iteration
125 Alignment
134 Semaphore
136 Debugging
139 Mutexes
142 decltype