http://www-graphics.stanford.edu/~seander/bithacks.html#CountBitsSetParallel
v = v - ((v >> 1) & (T)~(T)0/3); // temp
v = (v & (T)~(T)0/15*3) + ((v >> 2) & (T)~(T)0/15*3); // temp
v = (v + (v >> 4)) & (T)~(T)0/255*15; // temp
c = (T)(v * ((T)~(T)0/255)) >> (sizeof(v) - 1) * CHAR_BIT; // count
这与 Python 中的问题相同:来自 Bit Twiddling Hacks 的 C 代码的 Python 等价物?
我需要在 PHP 中使用此代码,独立于整数大小(上面的代码最多可以工作 128 位整数,这对我来说很好)。这是我尝试过的:
function countSetBits($int) {
$mask = (1 << PHP_INT_SIZE*8) - 1;
$int = $int - (($int >> 1) & (int) $mask/3);
$int = ($int & ((int) $mask/15)*3) + (($int >> 2) & ((int) $mask/15)*3);
$int = ($int + ($int >> 4)) & ((int) $mask/255)*15;
return ($mask & $int * ((int) $mask/255)) >> ((int) PHP_INT_SIZE - 1) * 8;
}
这不起作用的原因(在具有 64 位 PHP - Debian Squeeze 的 64 位机器上)是 PHP 似乎不支持 64 位无符号整数(如何在 PHP 上使用 64 位整数?)。恐怕我将不得不使用任意精度的数学库。还是有其他方法?