将std :: bitset分为两半?

Abd*_*man 4 c++ c++11 std-bitset

我正在实现DES算法,我需要分std::bitset<56> permutationKey成两半。

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;
Run Code Online (Sandbox Code Playgroud)

我试图打字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;
Run Code Online (Sandbox Code Playgroud)

我怎么能这样分裂bitset

Ric*_*ges 5

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() );
Run Code Online (Sandbox Code Playgroud)

  • 哇 !就是这么简单:-)。 (2认同)
  • 文档是新的黑色。你应该得到一些!;-) http://en.cppreference.com/w/cpp/utility/bitset (2认同)