看不明白,请高手解释下.
在一组数中如果有两个数出现了奇数次,求这两个数int get_odd(int a[], int n)
{
int ans = 0;
for (int i = 0; i < n; ++i)
{
ans ^= a[i];
}
return ans;
}
void get_two_odd(int a[], int n)
{
// 找到两个数的异或结果,得到两个数的不相同的二进制位信息
int dif = get_odd(a, n);
// 随便取一位,这里找最低的二进制位
int temp = dif & (dif - 1) ^ dif;
int x(0), y(0);
for (int i = 0; i < n; ++i)
{
// 将数分成两组,分别异或得出结果
if (a[i] & temp)
x ^= a[i];
else
y ^= a[i];
}
cout << x << " " << y << endl;
}