P14932 [北大集训 2025] 复读机
题目描述
考虑两位玩家进行如下的一个信任游戏(请注意,这个游戏可能与你所了解的某游戏有所不同):
- 有一台这样的机器:当一位玩家放进去一枚硬币,另一位玩家会得到三枚硬币。
- 游戏共进行 $2m$ 轮,两位玩家轮流行动,每次行动中,行动的玩家可以选择一下两种操作其一:
- 「合作」:放入一枚硬币;
- 「欺骗」:不放硬币。
- 若选择「合作」,则行动的玩家失去一枚硬币,另一位玩家获得三枚硬币;若选择「欺骗」,则无事发生。
- 每次行动后,另一位玩家会获知当前行动玩家的选择。
现在你将和「复读机」进行这个信任游戏,你先行动。「复读机」的策略可以用若干个长度不超过 $m$ 的 01 串构成的可重集合 $S$ 表示。他的具体策略为:先从集合中等概率随机选取一个 01 串 $s$,设其长度为 $k$,则他在第 $2i$ ($1 \le i \le m$) 轮(也就是他的第 $i$ 次行动)时策略为:
- 对于 $1 \le i \le k$,若 $s_i = 0$,则选择「合作」;若 $s_i = 1$,选择「欺骗」。
- 对于 $k < i \le m$,选择与你的上一次选择相同,也就是第 $2i-1$ 轮的选择。
现在你的对手「复读机」的策略池 $S$ 还未确定,他会进行 $n$ 次操作:每次操作包含一个长度不超过 $m$ 的 01 串 $s_i$ 和数量 $a_i$,表示向 $S$ 中加入 $a_i$ 个 $s_i$。特别地,如果 $a_i < 0$,则表示从 $S$ 中删除 $-a_i$ 个 $s_i$,其中 $S$ 中至少有 $-a_i$ 个 $s_i$,且删除后 $S$ 中至少还有 1 个 01 串。
你需要在每次操作后,计算出你在最优策略下,期望最多收益为多少硬币,每次操作后的询问相互独立。请注意,你已知集合 $S$,但你并不能得知他选择的 01 串 $s$,而你的每次行动都可以基于之前轮双方的选择进行决策。你只需要输出期望收益乘 $|S|$ 的值,可以证明是一个整数。
输入格式
从标准输入读入数据。
输入的第一行包含两个正整数 $n, m$。
输入的第 $i+1$ ($1 \le i \le n$) 包含一个长度不超过 $m$ 的 01 串 $s_i$ 和一个整数 $a_i$。
输出格式
输出到标准输出。
输出 $n$ 行,每行一个整数表示答案。
说明/提示
### 【子任务】
对于所有测试数据,均有:
- $1 \le n \le 3 \times 10^5$,$1 \le m \le 10^6$;
- 对于所有 $1 \le i \le n$,均有 $1 \le |s_i| \le m$,$1 \le |a_i| \le 10^6$,且 $\sum_{i=1}^{n} |s_i| \le 4 \times 10^5$。
- 对于所有 $1 \le i \le n$,若 $a_i < 0$,则 $S$ 中至少有 $-a_i$ 个 $s_i$,且删除后 $S$ 中至少还有 1 个 01 串。
| 子任务编号 | 分值 | $n \le$ | $m \le$ | 特殊性质 |
|:-:|:-:|:-:|:-:|:-:|
| 1 | 20 | $2000$ | $2000$ | A |
| 2 | 15 | $20$ | $10^6$ | 无 |
| 3 | 15 | $3 \times 10^5$ | $20$ | 无 |
| 4 | 15 | $3 \times 10^5$ | $10^6$ | B |
| 5 | 35 | $3 \times 10^5$ | $10^6$ | 无 |
特殊性质 A:对于所有 $1 \le i \le n$,均有 $a_i = 1$,且 $\sum_{i=1}^{n} |s_i| \le 5000$。
特殊性质 B:对于所有 $1 \le i < n$,均有 $|s_i| \ge |s_{i+1}|$。
### 【评分方式】
对于每个子任务:
1. 正确回答所有测试数据的第 $n$ 次操作后的答案,可获得该子任务 $40\%$ 的分数;
2. 正确回答所有测试数据的答案,可获得该子任务 $100\%$ 的分数。
注意:即使选手仅回答了第 $n$ 次操作后的答案,也需要按照输出格式输出 $n$ 个整数,分别对应每次操作后的答案。