4443 - 区间的异或和

通过次数

1

提交次数

3

时间限制 : 2 秒
内存限制 : 128 MB

输入一个长度为n的整数序列aaa。接下来再输入m个询问,每个询问输入一对l, r。对于每个询问,输出原序列中从第l个数到第r个数的异或和。

a[l] ^ a[l+1] ^ ... a[r]

输入

第一行包含两个整数n和m。 第二行包含n个整数,表示整数数列。 接下来m行,每行包含两个整数l和r,表示一个询问的区间范围。 保证1 \leq l \leq r \leq n

输出

输出m行,每行1个数字,表示区间内所有元素异或的值

样例

输入

5 3
2 1 3 6 4
1 2
1 3
2 4

输出

3
0
4

提示

1≤l≤r≤n, 1≤n,m≤10^6, 0≤a[i]≤10^8

请使用scanf printf进行输入输出

来源

原创