每日一题----2023.1.3

出来混,总要还的。

题目


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

输入格式

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

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

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

输出格式

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

数据范围

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

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

对于所有评测用例,1≤n,m≤1000000≤x<2^201≤li≤ri≤n0≤Ai<2^20


样例



题解



注意事项


  1. a^b=x则a=b^x。

  1. 1<<20表示在二进制中将1左移20为,即2^20。

  1. g[i]表示离第i个数最近的能取到一对满足情况的数所需的l的最大值。

  1. last[a]=i表示第i个数的数值是a,这样处理便于求g[i]。

  1. 对于第13,14行代码的顺序不能颠倒,原因如下:last[a] = i在前面的话,当x为0时,a ^ x等于a, 这个时候last[a ^ x] = last[a] = i,这个时候last未被更新为小于i即合法数据,不能参与运算,所以更新last[a]应该在后面。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值