最大异或和
时间限制:20s 空间限制:256MB
题目描述
我有一个数列a[1],a[2],…,a[n],每个a[i]是小于2^m的非负整数。
现在请您实现三种操作,格式说明如下:
1 x y w 对于所有x<=i<=y,将a[i]修改为a[i] xor w;
2 x y w 对于所有x<=i<=y,将a[i]修改为w;
3 从a[1],a[2],…,a[n]中选出若干个数,使它们的xor和最大,并输出这个最大值。
(xor表示按位异或运算)
输入格式
第一行三个整数n,m,q。
接下来n行为初始时a[1],a[2],…,a[n]的值。
接下来q行,每行表示一个操作。
(a[i],w的数值均用恰好m位的二进制01串表示,左边是最高位,右边是最低位,不足m位的在左边补0)
输出格式
对于每个3号操作,输出一个m位01串作为回答。
样例输入
3 4 7 0000 0011 0110 3 1 2 3 0010 3 2 1 2 0010 3 2 1 3 0000 3
样例输出
0110 0101 0110 0000
提示
N<=2000,M<=2000,Q<=2000
所有数据中,1,2操作保证1<=x<=y<=n
题目来源
2015年集训队互测