宏实现swap算法

 我认为的比较好的宏实现swap算法,但是都存在局限性。

方法1:#define  SWAP(a, b)  a=a+b;b=a-b;a=a-b;

这种算法可以说很易懂,甚至可以交换不同类型的变量的值。但是当a、b都较大时,会发生越界问题。但是小数交换非常不错。

 

方法2:#define  SWAP_(a,b)  a=a^b;b=a^b;a=a^b;

这种算法巧妙地运用了位运算,但是只适用于整型数据,无视越界问题。浮点数的交换连编译都通不过。但是整型数据很合适。

 

这么分析的话,还是不用宏方法为好吧!免的事多。感觉只适合写点小程序。

使用c++可以考虑使用std的swap算法(直接摘抄于effective c++):

namespace std
{
	template<typename T>
	void swap( T &a, T &b )
	{
		T temp(a);
		a = b;
		b = temp;
	}
}

 

c语言的话,则需要自己编写了。

void swap( int *a, int *b )
{
	if ( a!=b )
	{
		int temp = *a;
		*a = *b;
		*b = temp;
	}
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值