Saya mencari cara yang efisien untuk menentukan posisi bit paling tidak signifikan yang diatur dalam bilangan bulat, misalnya untuk 0x0FF0 akan menjadi 4.
Implementasi sepele adalah ini:
unsigned GetLowestBitPos(unsigned value)
{
assert(value != 0); // handled separately
unsigned pos = 0;
while (!(value & 1))
{
value >>= 1;
++pos;
}
return pos;
}
Ada ide bagaimana memeras beberapa siklus darinya?
(Catatan: pertanyaan ini untuk orang-orang yang menikmati hal-hal seperti itu, bukan untuk orang-orang yang mengatakan bahwa optimasi xyz itu jahat.)
[Sunting] Terima kasih semua orang atas idenya! Saya juga telah mempelajari beberapa hal lain. Keren!