Как замаскировать каждый бит числа, кроме одного случайного?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

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