写一个宏 可以将一个整数字的奇数位和偶数位交换
首先拿到这个题目时应该想到的是,他让你交换的是二进制数的奇偶位,交换十进制数的奇偶位是毫无意义的.
而要想要交换二进制的奇偶位可以想到用以前学过的按位与和左移右移来解决问题.
一、得到这个数的奇数位和偶数位
注意 ( 按位与的特点 : 任何数 &1等于它本身,0&任何数都为0 )
所以要得出奇数位 :给奇数位都&1,偶数位都&0
即 :num&0101 0101 0101 0101 0101 0101 0101 0101
得到它所有奇数位 num & 0x55555555
要得出偶数位 :给偶数位都&1,奇数位都&0
即 :num&1010 1010 1010 1010 1010 1010 1010 1010
得到它所有偶数位 num&0xaaaaaaaa
二、将奇数位和偶数位互换
奇数位左移一位到偶数位 (num&0x55555555)<<1
偶数位右移一位到奇数位 (num&0xaaaaaaaa)>>1
代码
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#define SWAP(num) ((((num)&0xaaaaaaaa)>>1)|(((num)&0x55555555)<<1))
int main() {
int num;
scanf("%d", &num);
printf("逆序为: %d", SWAP(num));
return 0;
}
即可将数的二进制表达的奇偶位进行交换