算法--实现两个数互换(不引入第三方变量)

m = 3
n = 8
现在是想m与n互换;

1、我们一般想到的就是引入第三方变量。
temp = m;
m = n;
n =temp;
这是比较常见的,但是现在我们不希望引入第三方变量,怎么做呢?

2、 int m = 8, n=3;
n = n+m = 11
m = n - m = 3;
n = n-m = 8;
但是这种方法又局限性,当n和m的值非常大,那就容易超出了int的范围;

3、n = n^m;
m = n^m; ========> (n^m)^m=n;
n = n^m; ========> (m^n)^n=m;

n异或一个数两次还是n本身;
开发的时候推荐使用第一种,因为容易想到。

你可能感兴趣的:(算法,互换)