本文主要是介绍LeetCode 热题100-96 只出现一次的数字,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
只出现一次的数字
给你一个 非空 整数数组 nums
,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。
示例 1 :
输入:nums = [2,2,1] 输出:1
示例 2 :
输入:nums = [4,1,2,1,2] 输出:4
示例 3 :
输入:nums = [1] 输出:1
提示:
1 <= nums.length <= 3 * 10e4
-3 * 104 <= nums[i] <= 3 * 10e4
- 除了某个元素只出现一次以外,其余每个元素均出现两次。
这道题目是技巧题,要求时间复杂o(n),空间复杂o(1),感觉想不出来特殊解法的话基本都是o(n)空间复杂度,没有接触过异或解题的我只能想出来o(n)...qwq
class Solution:def singleNumber(self, nums: List[int]) -> int:hashmap = {}for i in nums:if i not in hashmap:hashmap[i]=1else:del hashmap[i]for i in hashmap.keys():return i
看了一下其他大佬的解法,就是利用异或的知识来做,a ^ a = 0, a ^ 0 = a,另外异或还支持交换律,例如 a ^ b ^ a = ( a ^ a ) ^ b = 0 ^ b = b
class Solution:def singleNumber(self, nums: List[int]) -> int:res = 0for i in nums:res = res^ireturn res
这篇关于LeetCode 热题100-96 只出现一次的数字的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!