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

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

Сообщение Anonymous »

Я хочу ввести 16-битное число с несколькими установленными битами и вернуть число только с одним из установленных битов. Итак, введите 011 и случайным образом либо выведите 010, либо 001, либо введите 111 и получите либо 100, 010, либо 001. Контекст таков, что я пытаюсь позволить атаке случайным образом вызывать несколько статусных эффектов без необходимости выполнять для нее особые случаи, которые были бы раздражающими и повторяющимися.
Это хорошее решение?
u16int16_t setRandomBit(uint_t number) {
int bit_to_set = randomRange(1, std::popcount(type));// 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++»