[136] Single Number

1. 題目描述

Given an array of integers, every element appears twice except for one. Find that single one.

Note:
Your algorithm should have a linear runtime complexity. Could you implement it without using extra memory?
一個數組中除了一個元素其他元素都出現兩次,找到那個僅出現一次的元素。要求時間複雜度O(n)並且不使用額外的空間。

2. 解題思路

一開始的想法肯定是遍歷這個,兩個指針i,j進行比較,找到那個沒有重複的元素。但顯然這個辦法的超時了,最差的時間複雜度達到了O(n²)。之後的想法是使用一個HashSet,進行插入操作,如果沒有就插入,如果有就移除,最後剩下的那個就是那個單身狗,但這也不滿足題目要求,不能使用額外的空間。
之後覺得肯定要使用什麼數學的方法,但是百思不得其解啊,只好看了discuss。
原來!是用了異或的性質,數字A^A=0, 0^B=B, B^A=A^B,在這樣滿足交換律的條件下,對數組中的每個數抑或,最後剩下的那個數字就是那個單身狗!

3. Code

public class Solution {
    public int singleNumber(int[] nums) {
        // 因爲題目沒有給定如果輸入爲空的時候返回多少,假定了一定有至少一個元素
        int result = nums[0];
        for(int i = 1; i < nums.length; ++i)
        {
            // A^A = 0, B^0 = B, A^B = B^A
            // [1,2,3,1,1,3,2] -> [1^1^2^2^3^3^1]=1
            result = result ^ nums[i];
        }
        return result;
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章