前言
通过leetcode记录自己每天坚持刷题,以此监督自己的学习。不能放假了就懈怠😁
题目简介
题目传送地:剑指 Offer 56 - I. 数组中数字出现的次数
一个整型数组 nums
里除两个数字之外,其他数字都出现了两次。请写程序找出这两个只出现一次的数字。要求时间复杂度是O(n),空间复杂度是O(1)。示例 1:
输入:nums = [4,1,4,6]
输出:[1,6] 或 [6,1]
解析
这个题当时我就直接扫一遍放hash里取出出现次数为1的居然就直接过了,
看了官答才知道我就是个小瘪三啊,官答这思路不看答案真的真的不好想
代码
我的版本
class Solution:
def singleNumbers(self, nums: List[int]) -> List[int]:
sum_=sum(list(set(nums)))-sum(nums)
dic={}
for i in nums:
if i not in dic:
dic[i]=1
else:
dic[i]=2
ans=[]
for k,v in dic.items():
if v==1:
ans.append(k)
return ans
官方版本
class Solution:
def singleNumbers(self, nums: List[int]) -> List[int]:
x, y, n, m = 0, 0, 0, 1
for num in nums: # 1. 遍历异或
n ^= num
while n & m == 0: # 2. 循环左移,计算 m
m <<= 1
for num in nums: # 3. 遍历 nums 分组
if num & m: x ^= num # 4. 当 num & m != 0
else: y ^= num # 4. 当 num & m == 0
return x, y # 5. 返回出现一次的数字