在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次。请找出那个只出现一次的数字。
示例 1:
输入:nums = [3,4,3,3]
输出:4
示例 2:
输入:nums = [9,1,7,9,7,9,7]
输出:1
题解:
class Solution {
public int singleNumber(int[] nums) {
int n = nums.length;
int[] bits = new int[32];
int mask = 1;
// 位图
for(int i=0; i<32; ++i) {
// 先消除第一位
for (int j=0; j<n;++j) {
if ((nums[j] & mask) != 0) {
bits[i] = (bits[i] + 1) % 3;
}
}
mask = mask << 1;
}
int result = 0;
mask = 1;
for (int i=0; i<32; ++i) {
if (bits[i] == 1) {
result = result + mask;
}
mask = mask<<1;
}
return result;
}
}