描述
一个整型数组里除了两个数字只出现一次,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。

提示:输出时按非降序排列。

​数组中只出现一次的两个数字​

异或满足交换律,结合律.所以并且两个相同的数异或结果为0.根据这样的规律我们就可以通过异或解决此题。

public class FindNums {

/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param array int整型一维数组
* @return int整型一维数组
*/
public static int[] FindNumsAppearOnce (int[] array) {

int res = 0;
for (int i = 0; i < array.length; i++) {
res = res ^ array[i];
}

int magic = 1;
// 找到res最低位为1的那个位置。方便后续将数组分为两组
while((res & magic) != magic){
magic <<= 1;
}

int n1 = res;
int n2 = res;
for (int i = 0; i < array.length; i++) {
if ((array[i] & magic) == magic){
// 这一组,所有array[i]的某一位都是1
n1 = array[i] ^ n1;
}else{
// 这一组,所有array[i]的某一位都是0
n2 = array[i] ^ n2;
}
}

return n1 < n2 ? new int[]{n1,n2} : new int[]{n2,n1};
}

public static void main(String[] args) {
FindNumsAppearOnce(new int[]{4,6,1,1});
}
}