0136. Single Number
https://leetcode.com/problems/single-number
Description
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.
Example 1:
**Input:** nums = [2,2,1]
**Output:** 1
Example 2:
**Input:** nums = [4,1,2,1,2]
**Output:** 4
Example 3:
**Input:** nums = [1]
**Output:** 1
Constraints:
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.
ac
// b ^ b == 0, 0 ^ k == k, a ^ b ^ a ^ b ^ k == a ^ a ^ b ^ b ^ k == k
class Solution {
public int singleNumber(int[] nums) {
int res = 0;
for (int i : nums) {
res ^= i;
}
return res;
}
}
Last updated
Was this helpful?