第十三届蓝桥杯省赛A组(C++) 选数异或 2665

之前学逻辑运算的时候学到了异或,只知道相同为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;
}

瞅了一眼题解:动态规划,好家伙,学去了。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值