在某个位置或更低位置计算设置位的有效方法是什么?
给定std::bitset<64> bits
任意数量的位和位位置X
(0-63)
在X位或更低位计数位的最有效方法是什么,如果未设置X位,则返回0
注意:如果设置该位,则返回始终至少为1
蛮力方式很慢:
int countupto(std::bitset<64> bits, int X){ if (!bits[X]) return 0; int total=1; for (int i=0; i < X; ++i) { total+=bits[i]; } return total;}
这个count()
方法bitset
将为您popcount
提供所有位,但bitset
不支持范围
牧羊人nacy