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 }

 

你可能感兴趣的:(number)