Mahmoud and Ehab and yet another xor task

题意翻译

- 给定一个有 $n$ 个数的序列 $\{a_n\}$。 - 有 $q$ 次形如 `l x` 的询问,每次询问要求输出前 $l$ 个数中,有多少子序列满足异或和为 $x$。 - $1\leq n,q\leq 10^5$, $0\leq a_i<2^{20}$。

题目描述

Ehab has an array $ a $ of $ n $ integers. He likes the [bitwise-xor operation](https://en.wikipedia.org/wiki/Bitwise_operation#XOR) and he likes to bother Mahmoud so he came up with a problem. He gave Mahmoud $ q $ queries. In each of them, he gave Mahmoud 2 integers $ l $ and $ x $ , and asked him to find the number of subsequences of the first $ l $ elements of the array such that their bitwise-xor sum is $ x $ . Can you help Mahmoud answer the queries? A subsequence can contain elements that are not neighboring.

输入输出格式

输入格式


The first line contains integers $ n $ and $ q $ $ (1<=n,q<=10^{5}) $ , the number of elements in the array and the number of queries. The next line contains $ n $ integers $ a_{1} $ , $ a_{2} $ , $ ... $ , $ a_{n} $ $ (0<=a_{i}<2^{20}) $ , the elements of the array. The next $ q $ lines, each contains integers $ l $ and $ x $ $ (1<=l<=n $ , $ 0<=x<2^{20}) $ , representing the queries.

输出格式


For each query, output its answer modulo $ 10^{9}+7 $ in a newline.

输入输出样例

输入样例 #1

5 5
0 1 2 3 4
4 3
2 0
3 7
5 7
5 8

输出样例 #1

4
2
0
4
0

输入样例 #2

3 2
1 1 1
3 1
2 0

输出样例 #2

4
2

说明

The bitwise-xor sum of the empty set is 0 and the bitwise-xor sum of a set containing one element is that element itself.