您的位置:首页 > 其它

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

2015-08-09 21:49 232 查看
2712次
22.5%
1000ms
65536K

给定一个数组,除了一个数出现1次之外,其余数都出现3次。找出出现一次的数。
如:{1, 2, 1, 2, 1, 2, 7}, 找出7.
格式:
第一行输入一个数n,代表数组的长度,接下来一行输入数组A
,(输入的数组必须满足问题描述的要求),最后输出只出现一次的数。
要求:
你的算法只能是线性时间的复杂度,并且不能使用额外的空间哦~

样例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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: