异或在算法中的应用

异或,顾名思义,相同取0,相异取1,异或运算有结合律。在算法上有两个经典应用,一是交换两个数,二是寻找落单的数。

1.交换两个变量的值

与其它语言不同,C语言和C++语言的异或不用xor,而是用“^”,键入方式为Shift+6。(而其它语言的“^”一般表示乘方)
若需要交换两个变量的值,除了通常使用的借用中间变量进行交换外,还可以利用异或,仅使用两个变量进行交换,如:
1
2
3
a=a^b;
b=b^a;
a=a^b;
详解:
1
2
3
a1=a^b
b=a1^b
a=a1^b=a1^(a1^b)=a1^a1^b=b
注意:
1
a=a^b^(b=a); //此类形式是不正确的UB行为,在不同编译器中会有不同的结果,切勿使用
这样就完成了a与b的交换。
综上:同一变量与另一变量和其异或值异或等于自身。

2. 落单得数(1个落单,2个落单):

要求时间复杂度O(n),空间复杂度O(1)。关于复杂度多说一句:

O(n)这样的标志叫做渐近时间复杂度,是个近似值.各种渐近时间复杂度由小到大的顺序如下

O(1) < O(logn) < O(n) < O(nlogn) < O(n^2) < O(n^3) < O(2^n) < O(n!) < O(n^n)

         第一种思路是先快排,然后遍历寻找。时间复杂度是O(nlogn),空间复杂度是O(logn)。

         第二种思路是采用哈希表,时间复杂度是O(n),空间复杂度也是O(n)。

 第三种方法就是采用利用结合律的异或运算就可以了,这里面涉及到题目的延伸,如果两两成对的元素紧邻则直接异或,如果是散乱的则先快排再异或。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值