您的位置:首页 > 其它

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

2016-04-09 17:26 225 查看
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本身;

开发的时候推荐使用第一种,因为容易想到。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: