Как замаскировать каждый бит числа, кроме одного случайного?C++

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

Сообщение Anonymous »

Я хочу ввести 16-битное число с несколькими установленными битами и вернуть число только с одним из установленных битов. Итак, введите 011 и случайным образом либо выведите 010, либо 001, либо введите 111 и получите либо 100, 010, либо 001. Контекст таков, что я пытаюсь позволить атаке случайным образом вызывать несколько статусных эффектов без необходимости делать для нее особые случаи, которые были бы раздражающими и повторяющимися.
Похоже, что это решение всегда выводит только 1, а это не то, что я хочу.
u_int16_t setRandomBit(u_int16_tnumber) {
int bit_to_set = randomRange(1, __builtin_popcount(number));// popcount is the amount of set bits
int counter = 0;
for (int i = 0; i < 16; i++) {
if ((number >> i) && 1) {// if the bit is set
counter -= 1;
if (counter != bit_to_set) {
number = number && ~(1

Подробнее здесь: https://stackoverflow.com/questions/798 ... random-one
Ответить

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

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

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

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

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