x = X & (X - 1)

好玩意兒

剛剛看到的一個有趣的算法,可以把X最右邊的1去除掉。例如:

01111111 127
01111110 126

127 & 126 = 01111110

01011000 88
01010111 87

88 & 87 = 01010000

若要應用嘛,可用在想找出有幾個bit on的情況:

int quickBitcount(unsigned x)
{
int count = 0;

while (x) 
{
x &= (x-1);
count++;
}
return count;
}

from:http://sevensavants.blogspot.com/2010/01/x-x-x-1-trick.html