Lintcode: Single Number III


Given 2*n + 2 numbers, every numbers occurs twice except two, find them.

Example
Given [1,2,2,3,4,4,5,3] return 1 and 5

Challenge
O(n) time, O(1) extra space.

利用bitwise XOR的特點,n個數(0或1),如果1的個數為奇數,則n個數bitwise XOR結果為1,否則為0

先將所有的數異或,得到的將是x和y以后之后的值n。 找到這個數n的為1的某一位(為了方便就取最右邊為1的一位, n & ~(n-1),再將這一位為1的數異或,其余的數異或,得到的就是x和y的值。

 1 public class Solution {
 2     /**
 3      * @param A : An integer array
 4      * @return : Two integers
 5      */
 6     public List<Integer> singleNumberIII(int[] A) {
 7         // write your code here
 8         ArrayList<Integer> res = new ArrayList<Integer>();
 9         res.add(0);
10         res.add(0);
11         int n = 0;
12         for (int elem : A) {
13             n ^= elem;
14         }
15         n = n & (~(n-1));
16         for (int elem : A) {
17             if ((elem & n) != 0) {
18                 res.set(0, res.get(0)^elem);
19             }
20             else res.set(1, res.get(1)^elem);
21         }
22         return res;
23     }
24 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM