[CF1658D1] 388535 (Easy Version) 的题解
题目大意
给定 和一个长为 的所有数都不相等的序列 。请你找到任意一个数 满足序列 中的所有数异或上 后正好为 的一个排列。
- 组数据,。
- 。
- 。
思路
因为 的二进制为的取值并不会互相影响,所以我们可以将 和 数组内的二进制位分离出来讨论。
因为异或操作可以将二进制为取反或者保持不变,所以我们可以统计出每一个二进制位的 的数量。
如果 数组内某一位为 的数量的和与排列的数组内这一位为 的数量,那么 这一位就应该是 反之就是 。
AC Code
#include<bits/stdc++.h>
using namespace std;
void io(){ios::sync_with_stdio(false);cin.tie(nullptr);}
const int N=2e5+5;
int l,r,s[30][2];
void solve(){
cin>>l>>r;
for(int i=l,x,y;i<=r;i++){
cin>>x,y=i;
for(int j=1;j<=20;j++){
s[j][x&1]++;
s[j][y&1]--;
x>>=1,y>>=1;
}
}
int ans=0;
for(int i=20;i>=1;i--){
ans=ans<<1|(s[i][1]!=0);
s[i][1]=0;
}
cout<<ans<<'\n';
}
signed main(){io();
int T=1;
cin>>T;
while(T--){
solve();
}
return 0;
}