### Determining if an integer is a power of 2

unsigned int v; // we want to see if v is a power of 2Note that 0 is incorrectly considered a power of 2 here. To remedy this, use:

bool f; // the result goes here

f = (v & (v - 1)) == 0;

f = !(v & (v - 1)) &amp;& v;

### Compute the integer absolute value (abs) without branching

int v; // we want to find the absolute value of v

int r; // the result goes here

int const mask = v >> sizeof(int) * CHAR_BIT - 1;

r = (v + mask) ^ mask;

### Swapping values with XOR

#define SWAP(a, b) (((a) ^= (b)), ((b) ^= (a)), ((a) ^= (b))) This is an old trick to exchange the values of the variables a and b*without using extra space for a temporary variable*.

On January 20, 2005, Iain A. Fleming pointed out that the macro above doesn't work when you swap with the same memory location, such as SWAP(a[i], a[j]) with i == j. So if that may occur, consider defining the macro as (((a) == (b)) || (((a) ^= (b)), ((b) ^= (a)), ((a) ^= (b)))).

For many other bithacks click here

## No comments:

Post a Comment