/**spa
* 功能:交换某个整数的奇数位和偶数位,使用指令越少越好(即,位0与位1交换,位2与位3交换,以此列推)。.net
*/get
这题要交换的是整数二进制的奇数和偶数位。it
按照通常的解题确定会对每一位分别处理,即,将整数换成二进制,而后遍历一遍,交换奇数位和偶数位。这样效率不高,指令也很多。而后看大题目解析,感受用位操做很棒,如下为解题思路:class
(1)先操做奇数位,把101010(即0xAA)做为掩码,提取奇数位,并右移1位到偶数位置效率
(2)操做偶数位,把010101(即0x5555)做为掩码,提取偶数位,并左移一位到奇数位置遍历
(3)将两次操做结果合并成一个值。二进制
操做32位数时,掩码用8位十六进制便可,若是是64位,就要用16位十六进制掩码。static
这样作的好处是,不须要将整数换成二进制,直接位操做返回的就是交换后的十进制整数,操做少。co