【提示】
异或的一个性质:任何一个数字异或它自己都等于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]; } } } }