高效率計算某個位置或更低位置的設定位
問題陳述:
問題陳述:問題陳述:
#include <bitset> int popcount_subset(std::bitset<64> bits, int pos) { int high_bits_to_eliminate = 63 - pos; bits <<= high_bits_to_eliminate & 63; // Shift to place desired bits at the top return (bits[63] ? ~0ULL : 0) & bits.count(); // Broadcast high bit or return 0, then popcount }給定std::bitset使用任意位元值和位元位置X (0-63),確定對位置 X或更低的位元進行計數的最有效方法,或者如果未設定 X 處的位,則傳回 0。
最佳化解決方案:
條件 Popcount: AND 運算將位集與遮罩結合。如果 pos 處的位元被設置,則遮罩將為 ~0ULL,從而產生原始的 popcount。否則,遮罩將為 0,導致 popcount 為 0。
以上是如何有效計算位元集中某個位置或更低位置的設定位?的詳細內容。更多資訊請關注PHP中文網其他相關文章!