配对交换
链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台
题目意思就是交换相邻两个二进制位 ,用&分别取出even(偶位和)odd(奇位和)
偶位和用0xAAAAAAAA,奇位和用0x55555555即可,之后得到的偶位和左移,奇位右移,最后用 | 加起来即可
参考代码如下:
class Solution {
public:
int exchangeBits(int num) {
int even_bits = num & 0xAAAAAAAA;
int odd_bits = num & 0x55555555;
even_bits >>= 1;
odd_bits <<= 1;
return (even_bits | odd_bits);
}
};