// https://godbolt.org/z/jrGdT6665
#include <bitset>
#include <iostream>
using std::cout;
int main() {
std::bitset<8> bits{}; // 8 Bit dicht gepackt
bits.set(4); // 5. Bit auf 1
cout << bits << '\n'; // 00010000
bits.flip(); // alle Bits invertieren
cout << bits << '\n'; // 11101111
bits.set(); // alle Bits auf 1
bits.flip(1); // 2. Bit invertieren
std::cout << bits << '\n'; // 11111101
bits.reset(); // alle Bits auf 0
bits.set(4); // 5. Bit auf 1
cout << bits << '\n'; // 00010000
bits.flip(); // alle Bits invertieren
cout << bits << '\n'; // 11101111
bits.set(); // alle Bits auf 1
bits.flip(1); // 2. Bit invertieren
bits.flip(6); // 7. Bit invertieren
cout << bits << '\n'; // 10111101
// Verknüpfungen
std::bitset<8> zack("....####", 8, '.', '#');
cout << zack << '\n'; // 00001111
cout << (bits & zack) << '\n'; // 00001101
cout << (bits | zack) << '\n'; // 10111111
cout << (bits ^ zack) << '\n'; // 10110010
// andere Integertypen
std::bitset<64> b(0x123456789abcdef0LL);
cout << b << '\n';
// 0001001000110100010101100111100010011010101111001101111011110000
cout << std::hex << b.to_ullong() << '\n'; // umwandeln
// 123456789abcdef0
}