P11990 [JOIST 2025] 大会 / Conference
题目描述
K 主席计划在接下来 $N$ 天内举办一系列会议,每天都会举办恰好一场会议,且会议将在三个场馆之一举行:主场馆 A 或两个副场馆 B 和 C 中的一个。
每场会议的场馆信息由字符串 $S$ 给出,该字符串由 $\texttt{A}$、$\texttt{B}$、$\texttt{C}$ 和 $\texttt{?}$ 组成。对于第 $i$ 天($1 \leq i \leq N$),如果 $S$ 的第 $i$ 个字符是 $\texttt{A}$,则会议在场馆 A 举行;如果是 $\texttt{B}$,则在场馆 B 举行;如果是 $\texttt{C}$,则在场馆 C 举行;如果是 $\texttt{?}$,则表示第 $i$ 天的场馆尚未决定。
由于第一天和第 $N$ 天的会议预计会有大量参与者,因此已确定**这两天必须使用场馆 A**。
现在,K 主席需要为每个未决定的会议分配场馆(每个 $\texttt{?}$ 处可以选择 A、B 或 C)。此外,为了最小化场馆间移动的负担,他希望最小化满足以下条件的索引 $j$($1 \leq j \leq N-1$)的数量:第 $j$ 天的场馆与第 $(j+1)$ 天的场馆不同。
现在需要考虑 $Q$ 个分配场景。对于第 $k$ 个场景($1 \leq k \leq Q$)及其对应的问题描述如下:
- K 主席必须将 $X_k$ 个未决定的会议分配到场馆 A,$Y_k$ 个分配到场馆 B,$Z_k$ 个分配到场馆 C。
- 请确定在此条件下,满足「第 $j$ 天的场馆与第 $(j+1)$ 天的场馆不同」的最小可能索引 $j$ 的数量。
给定场馆信息和需要考量的场景,请编写程序回答这些问题。
输入格式
> $N$\
> $S$\
> $Q$\
> $X_1$ $Y_1$ $Z_1$\
> $X_2$ $Y_2$ $Z_2$\
> $\vdots$\
> $X_Q$ $Y_Q$ $Z_Q$
输出格式
输出 $Q$ 行。
在第 $k$ 行($1 \leq k \leq Q$)中,输出在 K 主席将 $X_k$ 个未决定会议分配到 A,$Y_k$ 个分配到 B,$Z_k$ 个分配到 C 的条件下,满足「第 $j$ 天的场馆与第 $(j+1)$ 天的场馆不同」的最小可能索引 $j$ 的数量。
说明/提示
### 样例解释
#### 样例解释 $1$
在第一个场景中,K 主席需要将 $5$ 个未决定会议中的 $1$ 个分配到场馆 A,$3$ 个分配到 B,$1$ 个分配到 C。例如,一种可能的分配结果会生成场馆信息字符串 $\texttt{ABBBBCCAA}$。此时,满足"第 $j$ 天的场馆与第 $(j+1)$ 天的场馆不同"的索引 $j$ 是 $1$、$5$、$7$,共 $3$ 个。由于无法将这个数量减少到 $2$ 或更少,因此第一行的正确输出是 $3$。
在第二个场景中,K 主席需要将 $5$ 个未决定会议中的 $4$ 个分配到 A,$1$ 个分配到 B。例如,一种可能的分配结果会生成字符串 $\texttt{AAABBACAA}$。此时,满足条件的索引 $j$ 是 $3$、$5$、$6$、$7$,共 $4$ 个。因此第二行的正确输出是 $4$。
在第三个场景中,K 主席需要将所有 $5$ 个未决定会议分配到 C。满足条件的索引 $j$ 是 $1$、$3$、$4$、$8$,共 $4$ 个。因此第三行的正确输出是 $4$。
该样例满足子任务 $1\sim 5,8$ 的限制。
#### 样例解释 $2$
该样例满足所有子任务的限制。
#### 样例解释 $3$
该样例满足子任务 $1,2,4,8$ 的限制。
### 数据范围
- $2 \leq N \leq 300\,000$;
- $S$ 是长度为 $N$ 且由 $\texttt{A}$、$\texttt{B}$、$\texttt{C}$ 和 $\texttt{?}$ 组成的字符串;
- $S$ 的首字符和末字符均为 $\texttt{A}$;
- $1 \leq Q \leq 200\,000$;
- $0 \leq X_k$($1 \leq k \leq Q$);
- $0 \leq Y_k$($1 \leq k \leq Q$);
- $0 \leq Z_k$($1 \leq k \leq Q$);
- $X_k + Y_k + Z_k$ 等于 $S$ 中 $\texttt{?}$ 的数量($1 \leq k \leq Q$);
- $N$、$Q$、$X_k$、$Y_k$、$Z_k$ 均为整数。
### 子任务
- $\text{Subtask 1 (4 pts)}$:$N \leq 50$ 且 $S$ 中 $\texttt{?}$ 的数量不超过 $13$;
- $\text{Subtask 2 (7 pts)}$:$N \leq 500$;
- $\text{Subtask 3 (13 pts)}$:$N \leq 5\,000$,$Q \leq 10$;
- $\text{Subtask 4 (18 pts)}$:$N \leq 5\,000$;
- $\text{Subtask 5 (12 pts)}$:$Q \leq 10$;
- $\text{Subtask 6 (8 pts)}$:$S$ 不含 $\texttt{C}$ 且所有 $Z_k = 0$($1 \leq k \leq Q$);
- $\text{Subtask 7 (13 pts)}$:所有 $Z_k = 0$($1 \leq k \leq Q$);
- $\text{Subtask 8 (25 pts)}$:无额外限制。