136.只出现一次的数字
描述
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
说明:
你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?示例 1:
输入: [2,2,1]
输出: 1示例 2:
输入: [4,1,2,1,2]
输出: 4
我v1.0
class Solution:
def singleNumber(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
s = []
for i in nums:
if i not in s:
s.append(i)
elif i in s:
s.remove(i)
return s[0]
很好,超出时间限制。早已在掌握之中。
下面的v2.0版本是为了缩减代码,但效率上没有任何改善。
for i in nums:
if nums.count(i) == 1:
return i
看了别人的代码,发现我第一个版本的思路还不错,只是将列表s换成字典会好很多。
s = {}
for i in nums:
if i in s.keys():
s.pop(i)
else:
s[i]=1
return list(s.keys())[0]
很好通过了,但是执行时间还有可提高空间下面看一看终极boss。
高级用法异或^
0异或任何数不变,任何数与自己异或为0。a⊕b⊕a=b。异或满足加法结合律和交换律。
666异或操作真的很强,我的提交执行用时战胜了95.75%的Python3提交记录。
v3.0
class Solution:
def singleNumber(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
res = 0
for i in nums:
res^=i
return res