写一个宏可以将一个数字的奇数位和偶数位交换。使用宏实现两个数中求较大值。

1.


#include <stdio.h>
#define SWAP(x) (((x&(0x55555555)) << 1) | ((x&(0xAAAAAAAA)) >> 1))
//0x55555555是十六进制的10101010101010101010101010101010,
int main()
{
	int x = 0;
	printf("请输入一个数字\n");
	scanf_s("%d", &x);
	printf("%d\n", SWAP(x));
	return 0;
}

 

//0x55555555是十六进制的10101010101010101010101010101010,
//将(x&(0x55555555))<<1; x按位与0x55555555后得到的二进制奇数位与x相同但偶数位均为0,然后再向左移一位,变成偶数位为原来的奇数位,且移动后奇数位全为0;

//将(x&(0xAAAAAAAA))>>1; x按位与0xAAAAAAAA后得到的二进制偶数位与x相同但奇数位均为0,然后再向右移一位,变成奇数位为原来的偶数位,且移动后偶数位全为0;

//最后将两个二进制按位或((x&(0x55555555))<<1) | ((x&(0xAAAAAAAA))>>1),便最终得到了交换后的数。

 

2.

#include <stdio.h>
#define MAX(a,b) a>b?a:b

int main()
{
	int x = 10;
	int y = 15;
	printf("两个数字中较大的是%d\n", MAX(x, y));
	return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值