2016-04-03 2 views
4

Я использую 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, как это?

+0

Ну, здесь может пригодиться хорошая старая бит-маскировка и смещение. –

+0

Ну, это последний вариант :-). –

+0

Вы можете даже подумать о том, чтобы предоставить шаблонную версию такой функции (создание экземпляров определенных размеров) для этого. –

ответ

4
std::bitset<56> permutationKey(0x133457799BBCDF); 
std::bitset<56> divider(0b00000000000000000000000000001111111111111111111111111111); 

auto rightKey = std::bitset<28> ((permutationKey & divider).to_ulong()); 
auto leftKey = std::bitset<28> (((permutationKey >> 28) & divider).to_ulong()); 
+1

Вау! Это было так просто :-). –

+2

документация - новый черный. Вы должны получить некоторые! ;-) http://en.cppreference.com/w/cpp/utility/bitset –

Смежные вопросы