当前位置:   article > 正文

蓝桥杯第十三届--选数异或

蓝桥杯第十三届--选数异或

题目描述

给定一个长度为 n 的数列 A1, A2, · · · , An 和一个非负整数 x,给定 m 次查询, 每次询问能否从某个区间 [l,r] 中选择两个数使得他们的异或等于 x 。

输入格式

输入的第一行包含三个整数 n, m, x 。

第二行包含 n 个整数 A1, A2, · · · , An 。

接下来 m 行,每行包含两个整数 li ,ri 表示询问区间 [li ,ri ] 。

输出格式

对于每个询问, 如果该区间内存在两个数的异或为 x 则输出 yes, 否则输出 no。

样例输入

4 4 1
1 2 3 4
1 4
1 2
2 3
3 3

样例输出

yes
no
yes
no

提示

显然整个数列中只有 2, 3 的异或为 1。

对于 20% 的评测用例,1 ≤ n, m ≤ 100;

对于 40% 的评测用例,1 ≤ n, m ≤ 1000;

对于所有评测用例,1 ≤ n, m ≤ 100000 ,0 ≤ x < 2^20 ,1 ≤ li ≤ ri ≤ n , 0 ≤ Ai < 2^20。 

  1. #include<iostream>
  2. using namespace std;
  3. #define int long long
  4. const int N=100010,M=1050000;
  5. int endpos[M];//存储距离当前位置i每个数的最大下标(目的是记录a[i]^x的最大下标);
  6. int a[N];
  7. int f[N];//f[i]记录x^a[k](1<=k<=i)的最后一个位置
  8. signed main(){
  9. int n,m,x;
  10. scanf("%lld%lld%lld",&n,&m,&x);
  11. for(int i=1;i<=n;i++){
  12. cin>>a[i];
  13. endpos[a[i]]=i;
  14. f[i]=max(f[i-1],endpos[x^a[i]]);
  15. }
  16. // for(int i=1;i<=n;i++) cout<<f[i]<<endl;
  17. while(m--){
  18. int l,r;
  19. scanf("%lld%lld",&l,&r);
  20. if(f[r]>=l&&f[r]!=r) printf("yes\n");
  21. else printf("no\n");
  22. }
  23. return 0;
  24. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/374357
推荐阅读
相关标签
  

闽ICP备14008679号