活在梦里

136. Single Number

题目

Given a non-empty array of integers nums, every element appears twice except for one. Find that single one.

Follow up: Could you implement a solution with a linear runtime complexity and without using extra memory?

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.

题解

  1. 位运算

异或运算有以下几个特点:

一个数和 0 做 XOR 运算等于本身:a⊕0 = a

一个数和其本身做 XOR 运算等于 0:a⊕a = 0

XOR 运算满足交换律和结合律:a⊕b⊕a = (a⊕a)⊕b = 0⊕b = b

class Solution {
    public int singleNumber(int[] nums) {
        int single=0;
        for (int num : nums) {
            single = single ^ num;
        }
        return  single;
    }
}
  1. 哈希表
class Solution {
    public int singleNumber(int[] nums) {
        HashMap<Integer, Integer> hs = new HashMap<>();
        for (int num : nums) {
            hs.put(num, hs.getOrDefault(num, 0) + 1);
        }
        int single = 0;
        for (Map.Entry<Integer, Integer> entry : hs.entrySet()) {
            if (entry.getValue() == 1) {
                single = entry.getKey();
            }
        }
        return single;
    }
}