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