题目描述
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现了三次。找出那个只出现了一次的元素。
输入: [2,2,3,2]
输出: 3
解题思路
《剑指offer》56题。如果一个数字出现3次,那么它的二进制表示的每一位(0或者1)也出现三次。我们把数组中所有数字的二进制表示的每一位都加起来。如果某一位的和能被3整除,那么那个只出现一次的数字二进制表示中对应的那一位是0,否则就是1。
参考代码
class Solution {
public:
int singleNumber(vector<int>& nums) {
int length = nums.size();
int bitSum[32] = {0};
for(int i = 0; i < length; i++){
unsigned int bitMask = 1;
for(int j = 31; j >= 0; j--){
if((nums[i] & bitMask) != 0)
bitSum[j]++;
bitMask <<= 1;
}
}
int res = 0;
for(int i = 0; i < 32; i++){
res <<= 1;
res += bitSum[i] % 3;
}
return res;
}
};