summaryrefslogtreecommitdiff
path: root/content/other/bitOps.cpp
blob: 8079305f0b096288ee2bbfbbcc70f67a5a635e7c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// Iteriert über alle Teilmengen einer Bitmaske
// (außer der leeren Menge).
for (int subset = bitmask; subset > 0;
     subset = (subset - 1) & bitmask)

// Zählt Anzahl der gesetzten Bits.
int numberOfSetBits(int i) {
	i = i - ((i >> 1) & 0x5555'5555);
	i = (i & 0x3333'3333) + ((i >> 2) & 0x3333'3333);
	return (((i + (i >> 4)) & 0x0F0F'0F0F) * 0x0101'0101) >> 24;
}

// Nächste Permutation in Bitmaske
// (z.B. 00111 => 01011 => 01101 => ...)
ll nextPerm(ll v) {
	ll t = v | (v - 1);
	return (t+1) | (((~t & -~t) - 1) >> (__builtin_ctzll(v) + 1));
}