在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次。请找出那个只出现一次的数字。
示例 1:
输入:nums = [3,4,3,3]
输出:4
示例 2:
输入:nums = [9,1,7,9,7,9,7]
输出:1
- 限制:
1 <= nums.length <= 10000
1 <= nums[i] < 231
思路:统计所有数字二进制上每一位的1出现的次数和,对1出现的次数除三取余,结果就是只出现一次的数字的二进制的值。此方法可以求一个数字只出现一次,其它数字出现m次的解
int singleNumber(vector<int>& nums) {
vector<int> vec(32, 0);
for (int tmp : nums) {
int j = 0;
while (tmp) {
vec[j++] += tmp & 1;
tmp = tmp >> 1;
}
}
int res = 0;
for (int i = 31; i >= 0; i--) {
res = (res << 1) + vec[i]%3;
}
return res;
}