CFCF2056F2.Xor of Median (Hard Version)
省选/NOI-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
这是该问题的困难版本。本版本与其他版本的区别在于 t、k 和 m 的约束更高。只有在你解决了所有版本的问题后,才能进行 hack。
一个长度为 n 的整数序列 a 被称为“好序列”,如果满足以下条件:
- 设 cntx 表示 x 在序列 a 中出现的次数。对于所有满足 0≤i<j<m 的数对,至少有以下三种情况之一成立:cnti=0,cntj=0,或者 cnti≤cntj。换句话说,如果 i 和 j 都在序列 a 中出现,那么 i 的出现次数不超过 j 的出现次数。
给定整数 n 和 m。请计算所有长度为 n、满足 0≤ai<m 的好序列 a 的中位数的按位异或和。
注意,n 的值可能非常大,因此以其二进制表示给出。
∗ 序列 a 的中位数定义为其第 ⌊2n+1⌋ 小的元素。
输入格式
每组测试包含多组数据。第一行包含测试用例数 t(1≤t≤104)。每组测试数据描述如下。
每组测试数据的第一行包含两个整数 k 和 m(1≤k≤2×105,1≤m≤109),分别表示 n 的二进制长度和序列元素的上界。
第二行包含一个长度为 k 的二进制字符串,表示 n 的二进制表示,且没有前导零。
保证所有测试用例的 k 之和不超过 2×105。
输出格式
对于每组测试数据,输出一个整数,表示所有长度为 n、满足 0≤ai<m 的好序列 a 的中位数的按位异或和。
输入输出样例
输入#1
6 2 3 10 2 3 11 5 1 11101 7 9 1101011 17 34 11001010001010010 1 1000000000 1
输出#1
3 2 0 8 32 0
说明/提示
在第一个样例中,n=102=2,m=3。所有元素小于 m 的序列有:[0,0],[0,1],[0,2],[1,0],[1,1],[1,2],[2,0],[2,1],[2,2]。这些序列都是好序列,因此答案为:0⊕0⊕0⊕0⊕1⊕1⊕0⊕1⊕2=3。
在第二个样例中,n=112=3,m=3。一些好序列有 [2,2,2]、[1,0,1] 和 [2,0,1]。但序列 [2,0,0] 不是好序列,因为 cnt0=2,cnt2=1。此时若取 i=0,j=2,i<j 成立,但 cnti≤cntj 不成立。