Я использую DES алгоритм, и мне нужно разделить std::bitset<56> permutationKey
на две половины.split std :: bitset в двух половинах?
std::bitset<56> permutationKey(0x133457799BBCDF);
std::bitset<28> leftKey;
std::bitset<28> rightKey;
std::bitset<56> divider(0b00000000000000000000000000001111111111111111111111111111);
rightKey = permutationKey & divider;
leftKey = (permutationKey >> 28) & divider;
Я попытался типаж bitset<56>
к bitset<28>
, но это не сработало.
Другой способ добиться того же - перебрать и назначить каждый бит отдельно. Я хочу добиться этого, не используя циклы, должен быть другой способ.
я был в состоянии сделать это с примитивными типами
uint64_t key = 0b0001010101010101110110001100001110000011111100000000011111000000;
//00010101.01010101.11011000.11000011---|---10000011.11110000.00000111.11000000
uint32_t right = (uint32_t)key;
uint32_t left = key >> 32;
Как я могу расколоть bitset
, как это?
Ну, здесь может пригодиться хорошая старая бит-маскировка и смещение. –
Ну, это последний вариант :-). –
Вы можете даже подумать о том, чтобы предоставить шаблонную версию такой функции (создание экземпляров определенных размеров) для этого. –