一. 有牛人设计的算法如下:
unsigned
int bit_reverse(unsigned
int n)
{
n = ((n
>> 1)
& 0x55555555)
| ((n
<< 1)
& 0xaaaaaaaa);
n = ((n
>> 2)
& 0x33333333)
| ((n
<< 2)
& 0xcccccccc);
n = ((n
>> 4)
& 0x0f0f0f0f)
| ((n
<< 4)
& 0xf0f0f0f0);
n = ((n
>> 8)
& 0x00ff00ff)
| ((n
<< 8)
& 0xff00ff00);
n = ((n
>> 16)
& 0x0000ffff)
| ((n
<< 16)
& 0xffff0000);
return n;
}
譬如abcdefgh -----> hgfedcba
1. 先进行奇偶位对换以一位为单位, badcfehg
2. 进行奇偶位对换以两位为单位,dcbahgfe
3. 进行奇偶位对换以四位为单位,hgfedcba
呵呵,正式翻转过来了。
二,最简单的方法
unsigned int ReverseBitsInWord00(unsigned int Num)
{
unsigned int ret = 0;
int i;
for(i=0;i<32;i++)
{
ret <<= 1;
ret |= Num & 1;
Num >>= 1;
}
return ret;
}就是将取出来的最低位往最高位挪动。
本文介绍了一种快速实现二进制位反转的算法,通过位操作技巧简化了位翻转的过程,适用于不同长度的数据处理。该算法包括基本原理、步骤演示以及与直接方法的对比分析。
3340

被折叠的 条评论
为什么被折叠?



