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

本文介绍了一种通过位操作实现整数二进制位奇偶交换的方法,并提供了C语言实现示例。通过按位与和按位或操作,巧妙地实现了数值中奇数位与偶数位的互换。

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

#define _CRT_SECURE_NO_WARNINGS 1

#include <stdio.h>
#include <stdlib.h>
#include <windows.h>

#define EXCHANGE(n)  (((n)&0x55555555)<<1)|(((n)&0xaaaaaaaa)>>1)

//0x是十六进制  
//奇数位与1偶数位与0得到奇数位 n&0101 0101 0101 0101 0101 0101 0101 0101
//奇数位与0偶数位与1得到偶数位 n&1010 1010 1010 1010 1010 1010 1010 1010
//奇数位左移一位,偶数位右移一位分别得到交换的奇偶位
//两者或后得到交换后的数的二进制数

int main()
{
	int n = 0;
	int m = 0;
	scanf("%d", &n);
	printf("交换前:%d\n", n);
	m = EXCHANGE(n);
	printf("交换后:%d\n", m);
	system("pause");
	return 0;
}

这里的奇数偶数进行交换是将他的二进制数进行的奇数偶数位进行交换,既然是对二进制进行交换了那大家自然也就想到了按位与按位或这种二进制操作,很多人纳闷0x55555555这个是个什么,这个实际上就是十六进制的10101010101010101010101010101010,就是他,所以开始先将n和他按位与,求出来n的所有偶数位置的数字,然后将求得的数左移一位,现在的数字就是将n的奇数位的所有内容放到了偶数位置,这时候只要求出来n的偶数为然后放到奇数位置就可以了,所以先移动n向右移虽然这时候n的32位少了一个,但是少的那个是32位的奇数位,所以并不影响,这时候将移动后的数字进和0x55555555进行按位与,就能求出来他的偶数位,然后将两个求得的数字进行或运算,就能将这个数字的32位二进制的奇数位和偶数位进行交换。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值