A93475.Iva & Pav
普及/提高-
通过率:0%
时间限制:1.00s
内存限制:128MB
题目描述
Iva 和 Pav 是塞尔维亚著名的竞赛编程情侣。在塞尔维亚,人们称 Pav 为“papuca”,因此他会满足 Iva 的所有愿望。
Iva 给了 Pav 一个长度为 n 的数组 a。
我们定义 f(l,r)=al & al+1 &…& ar(这里 $ & $ 表示按位与运算)。
注意,当 l>r 时,f(l,r) 没有定义。
Iva 还给了 Pav q 个询问。
每个询问包含两个数字 k 和 l,她希望 Pav 找出最大的下标 r(l≤r≤n),使得 f(l,r)≥k。
Pav 想要尽快解决这个问题,因为他不想让 Iva 不高兴。他需要你的帮助。
输入格式
第一行包含一个整数 t(1≤t≤104)——表示测试用例的数量。
每个测试用例的第一行包含一个整数 n(1≤n≤2⋅105)——数组 a 的长度。
每个测试用例的第二行包含 n 个整数 a1,a2,…,an(1≤ai≤109)——数组 a 的元素。
每个测试用例的第三行包含一个整数 q(1≤q≤105)——Iva 给 Pav 的询问数量。
接下来的 q 行,每行包含两个整数 l 和 k(1≤l≤n,1≤k≤109)——子区间的左端点和题目描述中的整数 k。
保证所有测试用例中 n 的总和不超过 2⋅105,所有测试用例中 q 的总和不超过 2⋅105。
输出格式
对于每个询问,输出最大的下标 r(l≤r≤n),使得 al & al+1 &…& ar≥k。
如果不存在这样的 r,输出 −1。
输入输出样例
输入#1
3 5 15 14 17 42 34 3 1 7 2 15 4 5 5 7 5 3 1 7 4 1 7 5 7 2 3 2 2 7 19 20 15 12 21 7 11 4 1 15 4 4 7 12 5 7
输出#1
2 -1 5 1 5 2 2 2 6 -1 5
说明/提示
在第一个测试用例中,n=5,数组 a=[15,14,17,42,34]。
第一个询问要求最大的下标 r,使得 f(1,r)≥7。
f(1,1)=15, f(1,2)=14, f(1,3)=0, f(1,4)=0, f(1,5)=0,所以 r=2 是答案。
第二个询问要求 f(2,r)≥15。由于不存在这样的 r,答案为 −1。
第三个询问要求 f(4,r)≥5。f(4,4)=42, f(4,5)=34,所以 r=5 是答案。
在第二个测试用例中,n=5,数组 a=[7,5,3,1,7]。
对于第一个询问,f(1,r)≥7。
f(1,1)=7, f(1,2)=5, f(1,3)=1, f(1,4)=1, f(1,5)=1,所以答案是 1。
对于第二个询问,f(5,r)≥7。
f(5,5)=7,所以答案是 5。
对于第三个询问,f(2,r)≥3。
f(2,2)=5, f(2,3)=1, f(2,4)=1, f(2,5)=1,所以答案是 2。