不一样的两个数交换方法
1 使用一个临时变量
//
int a,b;
int temp;
temp = a;
a = b;
b = temp;
这个算是最基础的两个数据交换的方法了,只要这个写,没有人会说不对。但是下面要介绍一种更好的方式——通过异或的方式,交换。
2 使用异或的方法(推荐)
// 注意判断 a!=b
int a,b;
a = a^b;
b = a^b;
a = a^b;
通过3次异或完成对两个数的交换,这个方法的原理是一个数与0异或还是它本身,及两个相同的数异或等于0;
解析:
a = a^b;
b = (a^b) ^b; //即 a ^ b ^b = a;
a = a^ b; //这时候公式等价于 a = (a^b) ^a,因为 a的值还是第一个表达式所得到的,而b在第二个表达式后,就等于了a的值了,所以两个相同的数异或等于0,a = b;
还有一种是可以通过加减乘除运算来交换,不过不推荐这个方式,因为两个数相加或相乘,有可能超过该数的范围,而引起异常。