#P2190. IMAWANOKIWA (popc)

IMAWANOKIWA (popc)

题目背景

IMAWANOKIWA - いよわ / 初音ミク

あなたの未来が見たかった。

题目描述

给你一个初始长度为 nn只包含 0,1,2\boldsymbol{0, 1, 2} 的序列 a1na_{1 \sim n},你可以执行以下操作:

  • 选择相邻的两个位置 jjj+1j + 1,删去 aj,aj+1a_j, a_{j + 1},并在原位置插入 popc(aj+aj+1)\mathrm{popc}(a_j + a_{j + 1}),后半部分序列因此向前移动一位。其中,popc(x)\mathrm{popc}(x) 表示 xx 在二进制表示下 11 的个数。

显然每次操作后序列长度都会减少 11,所以执行 n1n - 1 次操作后,这个序列会恰好剩下一个数。

记在所有可能的 n1n-1 次操作之后剩下的数的最小值为 tt,定义一个好的操作序列 pp 为一个长度为 n1n - 1 的正整数序列,其中 pip_i 表示第 ii 次操作所选择的 jj(显然 1pini1 \le p_i \le n - i),且满足按照这个操作序列操作之后剩下的数为 tt,你需要求出 tt字典序最小的好的操作序列。

如果你不会求出字典序最小的好的操作序列也可以获得部分分数,详见【评分方式】。

为了避免输出量过大,你只需要输出字典序最小的好的操作序列按照某种哈希方式得到的哈希值即可,详见【输出格式】。

输入格式

本题有多组测试数据。

第一行,一个正整数 TT,表示数据组数。接下来,对于每组数据:

  • 仅一行,一个长度为 nn 的字符串,其中第 ii 个字符表示 aia_i

输出格式

对于每组测试数据:

  • 输出一行,两个自然数 t,Hash(p)t, \mathrm{Hash}(p'),其中
    • 第一个数表示剩下的数的最小值;
    • 第二个数表示字典序最小的好的操作序列 pp' 的哈希值 Hash(p)\mathrm{Hash}(p'),定义见下。
    • 如果你输出的第二个数不正确,也可以获得部分分数,本题将使用自定义校验器做到这一点,详见【评分方式】。

B=13331B = 13331M=264M = 2^{64},我们定义一个正整数序列 c1lc_{1 \sim l} 的哈希值 Hash(c)\mathrm{Hash}(c)i=1lBlici\sum_{i = 1}^l B^{l - i}c_iMM 取模的结果。

提示:代码实现时可以使用 C++ 的 unsigned long long 类型的自然溢出来实现对 2642^{64} 取模的效果。

样例

7
110121
120202
1202
1121212
000
010101110
0112210112
1 31589928355420248
1 31587559229276557
2 177728893
2 15233797274127957404
0 13332
1 4098728445451629840
1 892964726593242284

样例 1 解释

对于第一组数据,字典序最小的好的操作序列 pp[1,3,2,1,1][1, 3, 2, 1, 1],按照该操作序列操作时,aa 序列的变化过程如下:

$$[1, 1, 0, 1, 2, 1]\\ [1, 0, 1, 2, 1]\\ [1, 0, 2, 1]\\ [1, 1, 1]\\ [1, 1]\\ [1] $$

所以你应输出的哈希值为 $\mathrm{Hash}([1, 3, 2, 1, 1]) = (1 \times 13331^4 + 3 \times 13331^3 + 2 \times 13331^2 + 1 \times 13331^1 + 1 \times 13331^0) \bmod 2^{64} = 31589928355420248$。

对于第二组数据,字典序最小的好的操作序列 pp[1,2,2,1,1][1, 2, 2, 1, 1],按照该操作序列操作时,aa 序列的变化过程如下:

$$[1, 2, 0, 2, 0, 2]\\ [2, 0, 2, 0, 2]\\ [2, 1, 0, 2]\\ [2, 1, 2]\\ [2, 2]\\ [1] $$

样例 2

见附件中的 popc/popc2.inpopc/popc2.ans

该组样例共有十组测试数据,所有测试数据均满足 n=105n = 10^5,其中测试数据 151 \sim 5 满足序列 aa 中不存在 006106 \sim 10 满足序列 aa 中不存在 11

样例 3

见附件中的 popc/popc3.inpopc/popc3.ans

该组样例共有四十组测试数据,其中测试数据 1101 \sim 10 满足 n=300n = 300112011 \sim 20 满足 n=3000n = 3000213021 \sim 30 满足 n=3×104n = 3 \times 10^4314031 \sim 40 满足 n=105n = 10^5

评分方式

本题将使用自定义校验器计算你获得的部分分数。

对于一个测试点,如果你存在数据输出的最小值不正确,那么无法获得该测试点的分数。

对于一个测试点,如果你每组数据输出的最小值正确,但是存在数据求出的字典序最小的好的操作序列的哈希值不正确,那么可以获得该测试点 25%25\% 的分数(即 11 分,见【数据范围】)。注意你仍需输出任意一个 [0,264)\boldsymbol{[0, 2^{64})} 内的整数表示你的方案的哈希值。

对于一个测试点,如果你每组数据输出的最小值正确,且求出的字典序最小的好的操作序列的哈希值正确,那么可以获得该测试点的全部分数。

数据范围

对于所有测试数据,保证:1T2001 \le T \le 2002n1052 \le n \le 10^5,序列 aa 只包含 0,1,2\boldsymbol{0, 1, 2}

测试点编号 TT\le nn\le 特殊性质
131 \sim 3 1010 1010
464 \sim 6 300300
797 \sim 9 30003000
101210 \sim 12 3×1043 \times 10^4
131513 \sim 15 10510^5 序列 aa 中不存在 00
161916 \sim 19 序列 aa 中不存在 11
202120 \sim 21
222322 \sim 23 5050
242524 \sim 25 200200

下发文件

通过点击此链接下载下发文件。