2016-04-03 121 views
4

我正在實現DES算法,我需要將std::bitset<56> permutationKey分爲兩部分。將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 –