Q40 数组中只出现一次的数字 位运算

本文介绍了一种在整型数组中查找两个仅出现一次的数字的方法。通过使用位运算、计数和字典记录等技术,文章详细解释了四种不同策略的实现过程,包括异或运算、直接计数及字典记录元素出现次数。

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

题目描述

一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。

方法一:

# -*- coding:utf-8 -*-
class Solution:
    # 返回[a,b] 其中ab是出现一次的两个数字
    def FindNumsAppearOnce(self, array):
        # write code here
        res = []
        for num in array:
            if num in res:
                res.remove(num)
            else:
                res.append(num)
        return res
方法二:位运算

位运算中异或的性质:两个相同数字异或=0,一个数和0异或还是它本身。
当只有一个数出现一次时,我们把数组中所有的数,依次异或运算,最后剩下的就是落单的数,因为成对儿出现的都抵消了。
根据异或的结果1所在的最低位,把数字分成两半,每一半里都还有只出现一次的数据和成对出现的数据 这样继续对每一半进行异或则可以分别求出两个只出现一次的数字

python 位运算
&是按位逻辑运算符,比如5 & 6,5和6转换为二进制是101和110,此时101 & 110=100,100转换为十进制是4,所以5 & 6=4

|是按位或逻辑运算符,比如5|6,就是101|110,得到111=7,所以最后结果为7

是按位异或逻辑运算符,比如56,其实是101110,结果是011,所以56的答案是3

Python bin() 函数

>>>bin(10)
'0b1010'
>>> bin(20)
'0b10100'

解题代码:

# -*- coding:utf-8 -*-
class Solution:
    # 返回[a,b] 其中ab是出现一次的两个数字
    def FindNumsAppearOnce(self, array):
        # write code here
        num = 0 
        for i in array:
            num ^=i #数组中的数字相异或 得到两个出现一次数字的异或结果
        first = 0
        while first&num==0:#得到异或第一个1出现的位置 也就是两个数字出现不同的首个位置
            first+=1
        result=[0,0]
        for item in array:
            if item&first==0:
                result[0]^=item
            else:
                result[1]^=item
        return result

方法三:
count算次数 次数为1的输出

方法四:
字典记录元素出现次数 次数为1 的输出
来源:牛客网 Husterking
https://www.nowcoder.com/questionTerminal/e02fdb54d7524710a7d664d082bb7811?answerType=1&f=discussion
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值