Каков самый быстрый способ вычислить количество бит, необходимых для хранения числа?C++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Каков самый быстрый способ вычислить количество бит, необходимых для хранения числа?

Сообщение Anonymous »

Я пытаюсь оптимизировать некоторые процедуры упаковки и распаковки битов. Чтобы выполнить упаковку, мне нужно вычислить количество битов, необходимых для хранения целочисленных значений. Вот текущий код.

if (n == -1) return 32;
if (n == 0) return 1;
int r = 0;
while (n)
{
++r;
n >>= 1;
}
return r;


Подробнее здесь: https://stackoverflow.com/questions/272 ... e-a-number
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»