进阶两数交换的方法论

今天我们来看一个简单的问题,大家对交换两个数字有多少想法呢,先看看这个。

以下我们全都以1,2,为例。

#include <stdio.h>
void swap(int a,int b)
{
	int t;
	t=a;
	a=b;
	b=t;
}
int main()
{
	int a=1,b=2;
	swap(a,b);
	printf("a=%d b=%d\n",a,b);
	return 0;
}

请问这个代码会输出什么?很明显,这个函数并不能起到交换a,b的目的,主函数中的a,b的值并没有发生改变,我们要了解传值和传址的问题,所以它会这样。

a=1 b=2

--------------------------------
Process exited after 0.4186 seconds with return value 0
请按任意键继续. . .

那么该如何交换呢。

方法一:借助中间变量

#include<stdio.h>
int main()
{
	int a=1,b=2,t;
	t=a;
	a=b;
	b=t;
	printf("a=%d b=%d\n",a,b);
	return 0;
}

这种临时变量法是最简单和最常见的方法,它的使用领域非常广泛且常见。

方法二:函数

上面例子中的函数没有作用,那么该如何使用函数呢。

#include <stdio.h>
void swap(int *a,int *b)
{
	int t;
	t=*a;
	*a=*b;
	*b=t;
}
int main()
{
	int a=1,b=2;
	swap(&a,&b);
	printf("a=%d b=%d\n",a,b);
	return 0;
}

我们用变量地址,交换它们的地址即可以改变它们的值。

方法三:加减交换法

#include<stdio.h>
int main()
{
	int a=1,b=2;
	a=a+b;
	b=a-b;
	a=a-b;
	printf("a=%d b=%d\n",a,b);
	return 0;
}

这个方法处就是不需要中间变量,先使用a+b保存a的值,即b=a-b=a=b-b=a;达到交换的目的,缺点是a+b的结果可能越界。

方法四:乘除交换法

#include<stdio.h>
int main ()
{
	int a=1,b=2;
	a=a*b;
	b=a/b;
	a=a/b;
	printf("a=%d b=%d\n",a,b);
	return 0;
}

这里类似加减,只是了换成乘法和除法,但其缺点更明显,乘法越界的可能性更大。

方法五:异或交换法

#include<stdio.h>
int main()
{
	int a=1,b=2;
	a=a^b;
	b=a^b;
	a=a^b;
	printf("a=%d b=%d\n",a,b);
	return 0;
}

这里是二进制位运算的方法,异或的运算法则为相同为0,不同为1,利用异或可以轻松达到目的。

这种方法十分完美,没有越界问题等;建议掌握。

结果如下:

a=2 b=1

--------------------------------
Process exited after 0.4051 seconds with return value 0
请按任意键继续. . .

方法五:位移交换法

#include<stdio.h>
int main()
{
	int a=1,b=2;
	 a<<=16;				//a=a<<16;
	 a|=b;					//a=a|b;
	 b=a>>16;				
	 a=a&0xffff;
	printf("a=%d b=%d\n",a,b);
	return 0;
}

这里比较难理解,建议自己实际用草稿操作一遍理解,可以直观的体会到方法的效果。

原理是把原来的int类型的a的值拆分成高16位和低16位,相当于多了16位的暂存空间可以周转,缺点是如果a或者b超过了16位,这种方法就会出错。所以实际不建议大家使用。

最后,我们可以将这些方法包装成函数使用,统称方法二的函数法。

好了,就讲到这里吧,希望通过上述文章让大家对交换两变量值有重新的认识,感谢各位的耐心阅读!

  • 17
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值