之前学逻辑运算的时候学到了异或,只知道相同为0,相异为1,也是一个模2运算。
再次查阅资料了解到在写代码时表达方式是^
性质:(1)任何数和0异或等于任何数 (2)任何数和自己异或等于0
(3)A^B=x成立时,有A^x=B
题目描述:给定一个长度为 n 的数列 A1, A2, · · · , An 和一个非负整数 x,给定 m 次查询, 每次询问能否从某个区间 [l,r] 中选择两个数使得他们的异或等于 x 。
输入格式:
输入的第一行包含三个整数 n, m, x 。
第二行包含 n 个整数 A1, A2, · · · , An 。
接下来 m 行,每行包含两个整数 li ,ri 表示询问区间 [li ,ri ] 。
输出格式:
对于每个询问, 如果该区间内存在两个数的异或为 x 则输出 yes, 否则输出 no。
我的最初思路:
循环遍历,当然蓝桥杯绝对是会卡时间的,64分
#include <iostream>
using namespace std;
int a[100005];
int n,m,x;
int r,l;
int main()
{
cin>>n>>m>>x;
for(int i=1;i<=n;i++)
{
cin>>a[i];
}
int lim=0;
int k=0;
for(int i=0;i<m;i++)
{
cin>>r>>l;
for(int j=r;j<=l&&k==0;j++)
{
lim=j;
while(lim<=l)
{
if((a[j]^a[lim])==x)
{
cout<<"yes"<<endl;
k=1;
break;
}
lim++;
}
}
if(!k)
{
cout<<"no"<<endl;
}
k=0;
}
return 0;
}
瞅了一眼题解:动态规划,好家伙,学去了。