#ATarc178f. [ARC178F] Long Sequence Inversion

[ARC178F] Long Sequence Inversion

题目描述

给定正整数 NNMMKK 以及长度为 MM 的非负整数序列 A=(A0,A1,,AM1)A = (A_0, A_1, \dots, A_{M-1}),满足 2N1K<2N2^{N-1} \leq K < 2^N

在输入中,KK 以二进制表示为 NN 位的数字,其他整数以十进制表示。

另外,序列 AA 并未直接给出,而是通过以下方式描述:对于每个 i=0,1,,M1i=0, 1, \ldots, M-1,提供长度为 LiL_i 的整数序列 Xi=(Xi,0,Xi,1,,Xi,Li1)X_i = (X_{i,0}, X_{i,1}, \dots, X_{i,L_i-1}),使得 Ai=j=0Li12Xi,jA_i = \sum_{j=0}^{L_i-1} 2^{X_{i,j}}。条件是 $0 \leq X\_{i,0} < X\_{i,1} < \cdots < X\_{i,L\_i-1} < N$。

我们的目标是计算由以下规律构成的长度为 MKMK 的序列 B=(B0,B1,,BMK1)B = (B_0, B_1, \dots, B_{MK-1}) 的逆序对数,并输出该值对 998244353998244353 取模的结果。

  • 对于任意 0a<K0 \leq a < K 和任意 0b<M0 \leq b < M,有:
    • BaM+bB_{aM+b} 等于 popcount(aANDAb)\operatorname{popcount}(a \operatorname{AND} A_b) 除以 22 的余数。

其中,按位与运算符 AND\operatorname{AND} 是怎样运算的?对整数 AABB,其按位与运算 AANDBA \operatorname{AND} B 在二进制表示下的第 2k2^k 位(k0k \geq 0)的值,当且仅当 AABB 在该位上均为 11 时为 11,否则为 00

例如,3AND5=13 \operatorname{AND} 5 = 1(二进制表示为 011AND101=001011 \operatorname{AND} 101 = 001)。不论先后顺序,多个整数按位与的结果是稳定的,可表达为 $(((p\_1 \operatorname{AND} p\_2) \operatorname{AND} \cdots) \operatorname{AND} p\_k)$。

同时,popcount\operatorname{popcount} 函数作用于非负整数 xx,返回其二进制表示中 11 的总个数。具体来说,假设 x=i=0bi2ix = \sum_{i=0}^\infty b_i 2^i,则 popcount(x)=i=0bi\operatorname{popcount}(x) = \sum_{i=0}^\infty b_i。举例来说,1313 在二进制下是 1101,因此 popcount(13)=3\operatorname{popcount}(13) = 3

输入格式

从标准输入读取,格式如下:

NN MM KK L0L_0 X0,0X_{0,0} X0,1X_{0,1} \cdots X0,L01X_{0,L_0-1} L1L_1 X1,0X_{1,0} X1,1X_{1,1} \cdots X1,L11X_{1,L_1-1} \ldots LM1L_{M-1} XM1,0X_{M-1,0} XM1,1X_{M-1,1} \cdots XM1,LM11X_{M-1,L_{M-1}-1}

输出格式

输出计算得到的逆序对数结果对 998244353998244353 取模的值。

样例 1

输入

2 4
11
1 0
2 0 1
0
1 1

输出

9

样例 2

输入

3 3
101
2 1 2
2 0 1
1 0

输出

23

样例 3

输入

16 7
1101010000100110
11 0 1 2 3 7 10 11 12 13 14 15
7 4 6 8 10 11 12 13
6 0 1 6 8 10 12
8 0 3 5 6 10 11 12 13
10 0 1 2 3 4 5 6 8 12 13
9 3 4 5 6 8 9 11 14 15
8 0 4 7 9 10 11 13 14

输出

97754354

样例 4

输入

92 4
10101100101111111111011101111111101011001011111110011110111111101111111110100111100010111011
23 1 2 5 13 14 20 28 32 34 39 52 56 59 60 62 64 67 69 71 78 84 87 91
20 15 17 22 28 36 40 43 47 52 53 57 67 72 77 78 81 87 89 90 91
23 7 8 9 10 11 13 16 19 22 23 30 33 42 49 51 52 58 64 71 73 76 79 83
22 1 13 19 26 27 28 29 35 39 40 41 46 55 60 62 64 67 74 79 82 89 90

输出

291412708

说明/提示

  • 1N2×1051 \leq N \leq 2 \times 10^5
  • 1M2×1051 \leq M \leq 2 \times 10^5
  • 2N1K<2N2^{N-1} \leq K < 2^N
  • 0LiN0 \leq L_i \leq N
  • Li2×105\sum L_i \leq 2 \times 10^5
  • $0 \leq X\_{i,0} < X\_{i,1} < \cdots < X\_{i,L\_i-1} < N$
  • 所有输入都是整数
  • KK 已经用二进制表示
  • KK 以外其他数以十进制表示

请输出对 998244353998244353 取模的逆序对数量。

本翻译由 AI 自动生成