2016-04-03 13 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<28>bitset<56>を型キャストしようとしたが、それはうまくいきませんでした。

同じことを達成する他の方法は、各ビットを反復して個別に割り当てることです。ループを使わずにそれを達成したいのですが、別の方法が必要です。

は、私はこのような bitsetを分割することができますどのようにプリミティブ型

uint64_t key = 0b0001010101010101110110001100001110000011111100000000011111000000; 
        //00010101.01010101.11011000.11000011---|---10000011.11110000.00000111.11000000 
uint32_t right = (uint32_t)key; 
uint32_t left = key >> 32; 

でそれを行うことができましたか?

+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 –

関連する問題