当前位置: 首页 > news >正文

招聘网站开发方案docwordpress插件jetpack

招聘网站开发方案doc,wordpress插件jetpack,酒店网站设计模板,微信订阅号做微网站[蓝桥杯 2022 省 A] 选数异或 题目描述 给定一个长度为 nnn 的数列 A1,A2,⋯,AnA_{1}, A_{2}, \cdots, A_{n}A1​,A2​,⋯,An​ 和一个非负整数 xxx, 给定 mmm 次查询, 每次询问能否从某个区间 [l,r][l, r][l,r] 中选择两个数使得他们的异或等于 xxx 。 输入格式 输入的第一…

[蓝桥杯 2022 省 A] 选数异或

题目描述

给定一个长度为 nnn 的数列 A1,A2,⋯,AnA_{1}, A_{2}, \cdots, A_{n}A1,A2,,An 和一个非负整数 xxx, 给定 mmm 次查询, 每次询问能否从某个区间 [l,r][l, r][l,r] 中选择两个数使得他们的异或等于 xxx

输入格式

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

第二行包含 nnn 个整数 A1,A2,⋯,AnA_{1}, A_{2}, \cdots, A_{n}A1,A2,,An

接下来 mmm 行,每行包含两个整数 li,ril_{i}, r_{i}li,ri 表示询问区间 [li,ri]\left[l_{i}, r_{i}\right][li,ri]

输出格式

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

样例 #1

样例输入 #1

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

样例输出 #1

yes
no
yes
no

提示

【样例说明】

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

【评测用例规模与约定】

对于 20%20 \%20% 的评测用例, 1≤n,m≤1001 \leq n, m \leq 1001n,m100;

对于 40%40 \%40% 的评测用例, 1≤n,m≤10001 \leq n, m \leq 10001n,m1000;

对于所有评测用例, 1≤n,m≤105,0≤x<220,1≤li≤ri≤n1 \leq n, m \leq 10^5,0 \leq x<2^{20}, 1 \leq l_{i} \leq r_{i} \leq n1n,m105,0x<220,1lirin0≤Ai<2200 \leq A_{i}<2^{20}0Ai<220

蓝桥杯 2022 省赛 A 组 D 题。

分析

A组的题,题目有三种解法,但是这道题无论啥解法,实际上是万变不离其宗的,就是他的关键的对于某个点的预处理。想要解这题主要还是要想出这个处理。之所以写不同的这三种解法,主要是复习一下模板吧
首先,我们容易知道:若a^b=x,那么a^x=b,对于数组a[i],我们可以通过关系式,找到a[i]^x的左边的最靠近下标,明显我们需要找到最靠近的下标,而当这个下标是大于等于所需要找的区间的左端点,即可满足这个区间内可以找到两个数的异或为x。
当对于一个数,其左边没有数与其异或等于x时,那么就将其置为0,而当我们不断输入数字的时候,我们需要同时存储这个数的下标,方便循环到下一个下标的时候找到这个数字(通过a^x=b这样的关系),具体看代码

解法一:线段树

#include<bits/stdc++.h>
#define ll long long
using namespace std;
int t[400005],a[100005],Left[100005],pos[2000005];
inline void buildtree(int k,int l,int r){if(l==r){t[k]=Left[r];return;}int mid=(l+r)>>1;buildtree(k<<1,l,mid),buildtree(k<<1|1,mid+1,r);t[k]=max(t[k<<1],t[k<<1|1]);
}
inline int query(int k,int l,int r,int x,int y){if(l==x&&r==y)return t[k];int mid=(l+r)>>1;if(y<=mid)return query(k<<1,l,mid,x,y);elseif(x>mid)return query(k<<1|1,mid+1,r,x,y);else return max(query(k<<1,l,mid,x,mid),query(k<<1|1,mid+1,r,mid+1,y));
}
int main(){int n,m,x;cin>>n>>m>>x;for(int i=1;i<=n;++i){scanf("%d",&a[i]);Left[i]=pos[a[i]^x];pos[a[i]]=i;}buildtree(1,1,n);while(m--){int x,y;scanf("%d%d",&x,&y);int k=query(1,1,n,x,y);if(k>=x)printf("yes\n");else printf("no\n");}
}

解法二:DP

#include<bits/stdc++.h>
#define ll long long
using namespace std;
int f[100005],pos[5000005];
int main(){int n,m,x;cin>>n>>m>>x;for(int i=1;i<=n;++i){int a;scanf("%d",&a);f[i]=max(f[i-1],pos[a^x]);pos[a]=i;}while(m--){int l,r;scanf("%d%d",&l,&r);if(f[r]>=l)printf("yes\n");else printf("no\n");}
}

解法三:ST表

#include<bits/stdc++.h>
#define ll long long
using namespace std;
int st[100005][20],pos[5000005];
int main(){int n,m,x;cin>>n>>m>>x;for(int i=1;i<=n;++i){int a;scanf("%d",&a);st[i][0]=pos[a^x];pos[a]=i;}int k=log2(n);for(int i=1;i<=k;++i)for(int j=1;j+(1<<i)-1<=n;++j)st[j][i]=max(st[j][i-1],st[j+(1<<(i-1))][i-1]);while(m--){int l,r;scanf("%d%d",&l,&r);int len=log2(r-l+1);int p=max(st[l][len],st[r-(1<<len)+1][len]);if(p>=l)printf("yes\n");else printf("no\n");}
}
http://www.yayakq.cn/news/875307/

相关文章:

  • 用什么程序做资讯类网站企业服务公司简介怎么写
  • 住建局查询系统windows10优化软件
  • 教你做网站和学习教程熊掌号100大看免费行情的软件
  • wordpress 不显示分类中的某篇文章做网站seo的公司哪家好
  • 做学历的网站松原公司做网站的流程
  • 做购物网站能赚钱吗为什么企业需要建设网站
  • 哪些网站是做设计的中恒建设集团有限公司 网站
  • 广州万户网站公司百度首页排名代发
  • 在线做ppt的网站微信建设小网站链接
  • 东莞凤岗做网站南京网站推广排名前十
  • 四川省住房建设厅官方网站有赞商城
  • 做 理财网站有哪些福田网站建设-信科网络
  • 企业网站建设对网络营销的影响主要表现在( )背景视频素材下载免费
  • 网站建设实施方案ppthtml5单页网站
  • 上海外贸营销网站建设地址代理一个手游需要多少钱
  • 怎么更改织梦网站文章样式百度网站名称及网址
  • 网站建设公司咨询电话我的网站百度怎么搜索不到了
  • 优化精灵烟台seo网站推广费用
  • 建设局网站自查自纠网站维护包括哪些
  • 新乡做网站费用网站建设与管理用什么软件有哪些
  • 微魔方建站app上架应用市场需要什么条件
  • 建好网站后最怎么维护ipad wordpress 应用
  • 民治做网站公司代理彩票网站做链接
  • 甘肃三北防护林建设局网站wordpress aws
  • 学习软件有哪些合肥优化网站
  • 成都 网站开发公司手机可以建网站吗
  • 做网站首页cdrasp做的网站asp源代码
  • 扬州网站开发公司网站图标素材图片
  • 网站开发基础培训cms建站方案
  • 宜宾网站建设公司酒店行业的网站建设