私は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;
でそれを行うことができましたか?
ここで、良い古いビットマスキングとシフトが便利になるかもしれません。 –
これは最後のオプションです:-)。 –
これを行うには、そのような関数のテンプレートベースのバージョンを提供することも考えられます(特定のサイズのインスタンス化)。 –