1.分别取出所有奇数bit位和偶数bit位
0x55555555(对应二进制奇数bit位为1,偶数bit位全为0)&num
0xaaaaaaaa(对应二进制即偶数bit位为1,奇数bit位全为0)&num
2.将奇数bit位的所有数字<< 1,偶数bit位的数字>> 1,然后做或(|)或者加操作,即有宏定义如下:
#define EXCHANGE(num) (((0x55555555 & num) << 1) + ((0xaaaaaaaa & num) >> 1))
本文共 287 字,大约阅读时间需要 1 分钟。
1.分别取出所有奇数bit位和偶数bit位
0x55555555(对应二进制奇数bit位为1,偶数bit位全为0)&num
0xaaaaaaaa(对应二进制即偶数bit位为1,奇数bit位全为0)&num
2.将奇数bit位的所有数字<< 1,偶数bit位的数字>> 1,然后做或(|)或者加操作,即有宏定义如下:
#define EXCHANGE(num) (((0x55555555 & num) << 1) + ((0xaaaaaaaa & num) >> 1))
转载于:https://www.cnblogs.com/520xiuge/p/5393323.html