原文转载于http://www.cnblogs.com/ayanmw/p/3423712.html 点击打开链接
第一种方法是利用加减法实现两个变量的交换,
如:A=A+B;B=A-B;A=A-B;
缺陷: 如果 A+B 超出 A的返回 ,就会出错!使用时需时刻注意!
第二种方法是用位异或运算来实现,也是效率最高的一种,在大量数据交换的时候,效率明显优于前种方法,
如:
A=A^B;
B=A^B(B=B^A);位操作与先后顺序无关
A=A^B;
原理:利用一个数异或本身等于0和异或运算符合交换率。
异或的意思就是:不同 才可以得1,否则为0
// 异或
// 0^0=0
// 1^1=0
// 1^0=1
// 0^1=1