[CF1658D1] 388535 (Easy Version) 的题解

题目大意

给定 l,r 和一个长为 rl+1 的所有数都不相等的序列 a。请你找到任意一个数 x 满足序列 a 中的所有数异或上 x 后正好为 [l,l+1,,r1,r] 的一个排列。

  • t 组数据,1t105
  • 0=lr,ai<217
  • (rl+1)217

思路

因为 x 的二进制为的取值并不会互相影响,所以我们可以将 xa 数组内的二进制位分离出来讨论。

因为异或操作可以将二进制为取反或者保持不变,所以我们可以统计出每一个二进制位的 1 的数量。

如果 a 数组内某一位为 1 的数量的和与排列的数组内这一位为 1 的数量,那么 ans 这一位就应该是 1 反之就是 0

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;
}
posted @   未抑郁的刘大狗  阅读(8)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示