【提示】
异或的一个性质:任何一个数字异或它自己都等于0;
试着把原数组分成两个子数组,使得每个子数组包含一个只出现一次的数字,而其他数字都成对出现两次。

// 实在是没想出来,只想到了分成两组...

//num1,num2分别为长度为1的数组。传出参数
//将num1[0],num2[0]设置为返回结果
public class Solution {
    public void FindNumsAppearOnce(int[] array, int num1[], int num2[]) {

        int xor = 0;
        for (int i = 0; i < array.length; i++) {
            xor ^= array[i];
        }
        int k = 0;
        for (int i = 0; ; i++) {
            if ((xor & (1 << i)) != 0) {
                k = i;
                break;
            }
        }

        for (int i = 0; i < array.length; i++) {
            if ((array[i] & (1 << k)) != 0) {
                num1[0] ^= array[i];
            } else {
                num2[0] ^= array[i];
            }
        }

    }
}