python学习-异或找数字

本文介绍异或运算的基本规则及其应用,包括如何通过异或运算找出列表中缺失的数字及仅出现奇数次的数字。通过具体的Python代码示例,展示了异或运算在解决特定问题中的高效性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

异或是逻辑运算。

规则就是相同为0,不同为1。

1^1 = 0
0^1 = 1

3^4 #结果是7

3转换成2进制是011 , 4的2进制是100

011
100
———
111
#根据异或法则得到2进制111,就是10进制的7

------------------------------------------------------------------------------------------------------------------

#1找数字,列表中有9个不同的数字,范围1~9,给出的数组缺少一个数,找出这个数

list1= [2,1,4,3,5,7,8,9]
for i in range(1,10):
    if i in array1:
        continue
    else:
print(i)

  #result 6

#2找数字,列表中有多对重复偶数次的数字,只有一个重复奇数次,范围1~9,找出这个数

list1 = [3,1,1,1,2,2,1,3,4]
result = 0
for i in temp:
    result = result ^ i #异或
print(result)

#result 4

原理就是异或的运算法则,相同为0,不同为1




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值