【NOI2017】游戏 排行榜


时间限制: 1 s
空间限制: 524288 KB

题目描述

小 L 计划进行 n 场游戏,每场游戏使用一张地图,小 L 会选择一辆车在该地图上完成游戏。

小 L 的赛车有三辆,分别用大写字母 ABC 表示。地图一共有四种,分别用小写字母 xabc 表示。

其中,赛车 A 不适合在地图 a 上使用,赛车 B 不适合在地图 b 上使用,赛车 C 不适合在地图 c 上使用,而地图 x 则适合所有赛车参加。

适合所有赛车参加的地图并不多见,最多只会有 d 张。

n 场游戏的地图可以用一个小写字母组成的字符串描述。例如:S=xaabxcbc 表示小 L 计划进行 8 场游戏,其中第 1 场和第 5 场的地图类型是 x,适合所有赛车,第 2 场和第 3 场的地图是 a,不适合赛车 A,第 4 场和第 7 场的地图是 b,不适合赛车 B,第 6 场和第 8 场的地图是 c,不适合赛车 C

小 L 对游戏有一些特殊的要求,这些要求可以用四元组 (i,hi,j,hj) 来描述,表示若在第 i 场使用型号为 hi 的车子,则第 j 场游戏要使用型号为 hj 的车子。

你能帮小 L 选择每场游戏使用的赛车吗?如果有多种方案,输出任意一种方案。

如果无解,输出 -1。

输入格式

从标准输入读入数据。

输入第一行包含两个非负整数 n,d

输入第二行为一个字符串 S

n,d,S 的含义见题目描述,其中 S 包含 n 个字符,且其中恰好 d 个为小写字母 x

输入第三行为一个正整数 m ,表示有 m 条用车规则。

接下来 m 行,每行包含一个四元组 i,hi,j,hj ,其中 i,j 为整数,hi,hj 为字符 ABC,含义见题目描述。

输出格式

输出到标准输出。

输出一行。

若无解输出 -1。

样例输入

样例输出

样例解释

小 L 计划进行 3 场游戏,其中第 1 场的地图类型是 x,适合所有赛车,第 2 场和第 3 场的地图是 c,不适合赛车 C

小 L 希望:若第 1 场游戏使用赛车 A,则第 2 场游戏使用赛车 B

那么为这 3 场游戏分别安排赛车 ABA 可以满足所有条件。

若依次为 3 场游戏安排赛车为 BBBBAA 时,也可以满足所有条件,也被视为正确答案。

但依次安排赛车为 AABABC 时,因为不能满足所有条件,所以不被视为正确答案。

数据范围与提示

测试点编号ndm其他性质
1204
2n
35010
4n
510020
68
720040S中只包含c
8
98S中只包含x或c
10
111000200S中只包含c
12
138S中只包含x或c
14
155000010000
168S中只包含x或c
17
18500000100000
198S中只包含x或c
20

题目来源

NOI 2017 Day 1


关于接口中的数组初值说明(最后更新:2023年2月6日)

若题目要求实现函数接口,且该函数中存在仅用于输出的数组(如 void solve(int n, const int *in, int *out) 中的 out),那么除非另外说明,否则该数组在程序启动时的初值为 0

关于标准输出的说明(最后更新:2018年10月23日)

标准输出将被重定向到内存中,所以你的内存使用量也包括了你的标准输出的大小(向上取整到 4KB 的倍数)。

如果你的程序要进行大量输出,请考虑这一点。

关于提交的说明

你提交的代码将会被公开,所有人都可见。如果这不是你所期望的,或者如果想要删除已提交的代码,请联系管理员。




Judge Duck Online | 评测鸭在线
Server Time: 2025-08-20 16:14:54 | Loaded in 0 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠