leetcode刷题之260.只出现一次的数字 III

leetcode刷题之260.只出现一次的数字 III

  • 题目
    给定一个整数数组nums,其中恰好有两个元素只出现一次,其余所有元素均出现两次。找出只出现一次的那两个元素。
  • 示例 :
输入: [1,2,1,3,2,5]
输出: [3,5]
  • 注意
  1. 结果输出的顺序并不重要,对于上面的例子,[5,3]也是正确答案。
  2. 你的算法应该具有线性时间复杂度。你能否仅使用常数空间复杂度来实现?
  • 代码1:
class Solution:
    def singleNumber(self, nums: List[int]) -> List[int]:
        b = []
        for i in nums:
            if i not in b:
                b.append(i)
            else:
                b.remove(i)
        return b
# 执行用时 :1648 ms, 在所有 Python3 提交中击败了5.26%的用户
# 内存消耗 :13.9 MB, 在所有 Python3 提交中击败了99.56%的用户
  • 算法说明:
    建立一个空列表b,然后遍历a中的元素,如果当前的元素,在b中存在,则删除b中的元素,否则将元素添加到b中,遍历结束,输出b,即为只出现一次的元素。
  • 代码2:
class Solution:
    def singleNumber(self, nums: List[int]) -> List[int]:
        result = 0
        x = 0
        y = 0
        for i in nums:
            result ^= i
        n = len(bin(result))- 3
        for i in nums:
            if i >> n & 1:
                x ^= i
            else:
                y ^= i
        return [x,y]
# 执行用时 :48 ms, 在所有 Python3 提交中击败了96.95%的用户
# 内存消耗 :13.9 MB, 在所有 Python3 提交中击败了99.56%的用户
  • 算法说明:
    首先将所有的数进行异或运算,得到最后的结果,判断结果最高位1所处的位置,求出最高位的1;然后求出数组元素中对应位置的值,如果是1,则与x进行异或操作,如果是0,则与y进行异或操作。返回x,y即可。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

O_胡萝卜_O

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值