CF2170D Almost Roman

题目描述

我们定义一个只包含字母 “XVI” 的字符串的值如下: - 字母 'X' 的值为 $10$; - 字母 'V' 的值为 $5$; - 字母 'I' 的值为 $1$ 或 $-1$:如果它后面的位置上是字母 'X' 或 'V',则为 $-1$;否则为 $1$; - 整个字符串的值等于其中所有字母值的总和。 现在你得到了一个仅包含字符 “XVI?” 的字符串,并会询问 $q$ 次。 在第 $i$ 次询问时,会给出三个整数: - $c_X,~c_V,~c_I$ ——分别代表可用字母 'X'、'V' 和 'I' 的数量。 你需要求出,若将字符串中的所有问号用字母 'X'、'V'、'I' 替换(要求每种字母的使用次数不超过其可用数量),该字符串可以得到的最小值是多少。

输入格式

第一行包含一个整数 $t$($1\leq t\leq 10^4$)——表示测试用例的数量。 每个测试用例的第一行包含两个整数 $n$ 和 $q$($1\leq n,q \leq 3\times 10^5$)——表示字符串长度和询问数。 第二行给出一个长度为 $n$ 的字符串,字符串仅由 'X'、'V'、'I'、'?' 构成。 接下来的 $q$ 行,每行包含三个整数 $c_X,~c_V,~c_I$($0\leq c_X, c_V, c_I\leq n$)——分别表示本次查询可用的 'X'、'V'、'I' 的个数。 【附加输入约束】 - 所有测试用例中 $n$ 的总和不超过 $3 \times 10^5$; - 所有测试用例中 $q$ 的总和不超过 $3 \times 10^5$; - 对于每个询问都有 $c_X + c_V + c_I$ 大于等于字符串中问号 '?' 的数量。

输出格式

对于每个询问,输出一个整数——表示将所有问号替换为可用字母后,字符串可能取得的最小值。

说明/提示

(无) 由 ChatGPT 5 翻译