异或运算在数组查找中的应用

异或运算在数组查找中的应用

异或实现数的交换

从数组中找出出现奇数次的数(只有一个数出现奇数次,其他数出现偶数次)

从数组中找出出现奇数次的数(两个数出现奇数次,其他数出现偶数次)

#############异或实现数的交换##########
a=10
b=100
a = a ^ b
b = a ^ b
a = a ^ b
#print(a,b)

########异或查找出数组中出现奇数次的数########

###########数组中只有一个数出现奇数次,其他数都出现偶数次,找出出现奇数次的数##
# li=[1,9,9,8,8,6,4,6,5,4,4,4,1,1,1]
# eor=0
# for i in li:
#     eor^=i
# #print(eor)

###########数组中有两个数出现奇数次,其他数都出现偶数次,找出出现奇数次的数##
li=[1,9,9,8,8,6,4,6,5,4,4,4,1,1,1,7,7,7]
eor=0
for i in li:
    eor^=i   #循环一遍得到的eor=a^b(a,b为那两个出现奇数次的数)
    ###接下来想办法将a,b分离出来
rightone = eor & (~eor + 1)  #提取出eor(二进制位)最右边的1(eg:00000010,第7位为1),方法:自身与(取反+1)作与运算
#补码与原码的计算
print(rightone)
#a与b(二进制位)在第7位上,是不同的,分别为1或者0
#设置变量eor1,将数组中所有第7位为1的元素作异或运算,出现过偶数次的数异或为0,最后结果为a或者b(因为a和b在第7位不同),最后再将eor1与eor作异或运算,得到另一个元素(  a^(a^b)=b or b^(a^b)=a  )

eor1 =0
for i in li:
    if ( i & rightone):
        eor1^=i
print( eor1, eor1^eor )
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值