小技巧--使用异或来替换原本的常量交换

小技巧–使用异或来替换原本的常量交换

场景重现

我们在平时写代码的时候,倘若我们要交换ab的值,是不是经常会用到下面这个代码?

int temp = a;
a = b;
b = temp;

这个算是十分基本的交换方法,被人津津乐道。

但,从优化的角度,有没有想过,不去使用temp这个变量呢?

那么,不用变量如何交换呢?

就要使用到我们今天的主角–异或运算了。

先打个结论,刚才那行代码是完全等于下面这些代码的:

a = a ^ b;
b = a ^ b;
a = a ^ b;

为什么呢?请听我娓娓道来。

先来说一下异或运算

异或运算就是一种对二进制的一种运算。相同得 0 ,不同得 1。例:

1 ^ 0 = 1
0 ^ 1 = 1
0 ^ 0 = 0
1 ^ 1 = 0

如果是两个数的运算,就是:

4 ^ 5 =

4       0100
5       0101
       ------
        0001

又被称为不进位的相加。

同时又衍生出:

 n ^ n = 0
 n ^ 0 = n

同时异或满足结合律。

铺垫了这么多,该说一下为什么了。

我们把a的值设为 x , b的值设为 y。于是上面的变为:

a = a ^ b;  //此时a = x ^ y  b = y
b = a ^ b;  //此时a = x ^ y  b = x ^ y ^ y = x
a = a ^ b;  //此时a = x ^ y ^ x = y  b = x

你会惊讶的发现 a 和 b 调换完了。

这就是异或的魅力。

注意: 如果 a 和 b 指向的是同一个内存地址,那么这种方法就存在弊端,就会将原来的 a 和 b 都重置为0.

位运算详解以及有关的练习点击这里:“只出现一次的数字”系列 剑指offer–位运算学习(一)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值