CF711A Bus to Udayland
题目描述
ZS the Coder 和 Chris the Baboon 要去 Udayland!他们需要搭乘特别的 IOI 公交车才能到达那里。IOI 公交车有 $n$ 排座位。每排有 $4$ 个座位,中间由过道隔成两对。当 ZS 和 Chris 上车时,发现有些座位已经被占了。
ZS 和 Chris 是好朋友,他们坚持要坐在一对相邻的空座位上。如果两张座位在同一排并且在同一对中,则认为它们是相邻的。给定公交车的座位分布,请你帮他们确定是否有可用的相邻空座位,如果有,应该坐在哪里?
输入格式
第一行是一个整数 $n$,表示公交车的排数,$1 \leq n \leq 1000$。
接下来有 $n$ 行,每行恰好有 $5$ 个字符,前两个字符代表这一排的第一对座位,第 $3$ 个字符表示过道(始终为 $|$),最后两个字符代表第二对座位。
除去过道外,每个字符均为 'O' 或 'X','O' 表示空座,'X' 表示已占座位。具体可参考样例。
输出格式
如果 Chris 和 ZS 能坐在相邻的空座位上,第一行输出 "YES"(不带引号)。接下来输出 $n$ 行,表示修改后的公交车座位分布,把他们坐下的那两个座位(这一对 'O')替换为 '+' 号。新配置与原输入相比,仅有两个 'O' 被替换为 '+'。
如果不存在这样一对座位,输出一行 "NO"(不带引号)。
如果有多种解法,输出任意一种即可。
说明/提示
注意,相邻的两个座位必须在同一对,也就是不能跨过道。
下面是第一个样例的不合法配置,因为“+”座位不是同一对:
O+|+X
XO|XX
OX|OO
XX|OX
OO|OO
OO|XX
由 ChatGPT 5 翻译