Given a non-empty array of integers nums
, every element appears twice except for one. Find that single one.
You must implement a solution with a linear runtime complexity and use only constant extra space.
Input: nums = [2,2,1]
Output: 1
Input: nums = [4,1,2,1,2]
Output: 4
Input: nums = [1]
Output: 1
1 <= nums.length <= 3 * 104
-3 * 104 <= nums[i] <= 3 * 104
- Each element in the array appears twice except for one element which appears only once.
-
Time complexity:
O(n)
-
Space complexity:
O(n)
class Solution:
def singleNumber(self, nums: List[int]) -> int:
hash = {}
for i in nums:
hash[i] = hash.get(i, 0) + 1
for key, value in hash.items():
if value == 1:
return key
function singleNumber(nums: number[]): number {
let result = 0;
for (let num of nums) {
result ^= num;
}
return result;
}
function singleNumber(nums: number[]): number {
const n = nums.length;
const map = {};
for (let num of nums) {
if (num in map) {
map[num]++;
} else {
map[num] = 1;
}
}
for (let [key, value] of Object.entries(map)) {
if (value == 1) {
return +key;
}
}
return 0;
}