/**
* 思路:先操作奇数位,再操作偶数位。将数字n的奇数位右移1位,偶数位左移1位。
* @param x
* @return
*/
public static int swapOddEvenBits(int x){
//奇数位右移,0xaaaa aaaa=10101010 10101010 10101010 10101010 10101010 10101010 10101010 10101010b;
int odd=(x&0xaaaaaaaa)>>1;
//偶数位左移,0x5555 5555=01010101 01010101 01010101 01010101 01010101 01010101 01010101 01010101b;
int even=(x&0x55555555)<<1;
return odd|even;
}版权声明:本文为博主原创文章,未经博主允许不得转载。
9.5位操作(六)——交换某个整数的奇数位和偶数位,使用指令越少越好
原文:http://blog.csdn.net/shangqing1123/article/details/47316101