题目描述:
一个整型数组里除了两个数字之外,其他的数字都出现了偶数次。请写程序找出这两个只出现一次的数字。
代码
#include<algorithm>
using namespace std;
class Solution {
public:
void FindNumsAppearOnce(vector<int> data,int* num1,int *num2) {
int x_or = 0;
for (int d : data)
x_or ^= d;
//找出第一个为1的为位,很巧妙
x_or &= ~(x_or - 1);
//初始化为0,很重要
*num1 = 0, *num2 = 0;
for (int d : data)
if (x_or & d)
*num1 ^= d;
else
*num2 ^= d;
}
};