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

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本身;
开发的时候推荐使用第一种,因为容易想到。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值