暴力枚举后想到可以通过转二进制看1的个数来做,但这种方法在提交后是0分,示例都能过,因为本题测试点不能下载,不清楚错在哪里
#include<bits/stdc++.h>
using namespace std;
int n, t[32];
int main(){
cin >> n;
for (int i = 1; i <= n; i++) {
int x;
cin >> x;
for (int k = 30; k >= 0 && x > 0; k--) {
int m = 1 << k;
if (x >= m) {
x -= m;
t[k]++;
}
}
}
for (int i = 30; i >= 0; i--) {
if (t[i] >= 2) {
int m = 1 << i;
cout << m;
return 0;
}
}
cout << 0;
return 0;
}