Сортировка чисел с использованием обращенных битов в качестве ключа.
Этот код Python демонстрирует концепцию:
>>> sorted(range(1,128), key=lambda x: ('{:08b}'.format(x))[::-1])
[64, 32, 96, 16, 80, 48, 112, 8, 72, 40, 104, 24, 88, 56, 120, 4, 68, 36, 100, 20, 84, 52, 116, 12, 76, 44, 108, 28, 92, 60, 124, 2, 66, 34, 98, 18, 82, 50, 114, 10, 74, 42, 106, 26, 90, 58, 122, 6, 70, 38, 102, 22, 86, 54, 118, 14, 78, 46, 110, 30, 94, 62, 126, 1, 65, 33, 97, 17, 81, 49, 113, 9, 73, 41, 105, 25, 89, 57, 121, 5, 69, 37, 101, 21, 85, 53, 117, 13, 77, 45, 109, 29, 93, 61, 125, 3, 67, 35, 99, 19, 83, 51, 115, 11, 75, 43, 107, 27, 91, 59, 123, 7, 71, 39, 103, 23, 87, 55, 119, 15, 79, 47, 111, 31, 95, 63, 127]
Просмотр битовых комбинаций для каждого числа показывает, как / почему он работает:
>>> '{:08b}'.format(64)
'01000000'
>>> '{:08b}'.format(32)
'00100000'
>>> '{:08b}'.format(96)
'01100000'
Обратите внимание, что процесс также можно выполнять на лету, не требуя сортировки:
* * 1010
В C изменение битов - тривиальное упражнение:
long reverse(long x) {
long result = 0:
int i;
for (i=0 ; i<32 ; i++) {
result <<= 1;
result |= x & 1;
x >>= 1;
}
return result;
}