计蒜客 难题题库 015 单独的数字

给定一个数组,除了一个数出现1次之外,其余数都出现3次。找出出现一次的数。

如:{1, 2, 1, 2, 1, 2, 7}, 找出7.

格式:

   第一行输入一个数n,代表数组的长度,接下来一行输入数组A[n],(输入的数组必须满足问题描述的要求),最后输出只出现一次的数。

要求:

   你的算法只能是线性时间的复杂度,并且不能使用额外的空间哦~

样例1

输入:

4
0 0 0 5

输出:

5


#include<iostream>
using namespace std;

int main(){
    int n;
    cin >> n;
    int b[32] = {};
    int a;
    while(n--){
        cin >> a;
        for(int i = 0; i < 32; ++i){
            if(a & (1 << i)){
                b[i] = (b[i] + 1) % 3;
            }
        }
    }
    int res = 0;
    for(int i = 0; i < 32; ++i){
        res += b[i] *(1 << i);
    }
    cout << res << endl;
}


你可能感兴趣的:(OJ,计蒜客)