C语言:写一个宏可以将一个数字的奇数位和偶数位交换。

本文介绍了一种利用位操作实现数字中奇数位与偶数位交换的方法。通过巧妙地使用位掩码与位移操作,该方法能够高效地完成任务。示例代码展示了如何将一个整数的奇数位向左移动一位,偶数位向右移动一位,再将两者相加以得到最终结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

此题的解决思路为:将一个数字的奇数位提取出来并向左移动1位,偶数位提取出来并向右移动1位,将奇数位与偶数位移位后的值相加即可以实现。

例如:11----->1011

奇数位提取出来为0001---->向左移动1位为0010

偶数位提取出来为1010---->向右移动1位为0101

两个移位后的值相加为0111---->输出的值为7

这样就完成了奇数位和偶数位交换。

具体代码如下:

需要注意的是宏的使用要尽可能适当的多使用括号,以防操作符的优先级影响结果。

#include <stdio.h>
#include <stdlib.h>
#define SWAP(X) ((((X)&0x55555555)<<1)+(((X)&0xaaaaaaaa)>>1))
              //提取奇数位向左移动1位   //提取偶数位向右移动1位
int main()
{
	int n = 11;
	int ret = SWAP(n);
	printf("ret = %d\n", ret);
	system("pause");
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值