#ATarc157d. [ARC157D] YY Garden
[ARC157D] YY Garden
题目描述
在一个 行 列的网格中,每个格子上写有字符 X 或 Y。从上到下第 行,从左到右第 列的格子记作 。网格中的字符由 个字符串 给出,第 个字符串 的第 个字符表示格子 上的字符。
你可以在相邻的每两行之间和每两列之间设置横向或纵向的栅栏,栅栏可以相互交叉。设置栅栏后,“从某个格子出发,只能通过上下左右相邻的格子且不跨越栅栏所能到达的所有格子”被定义为一个区画(请参考样例 1 的说明)。
栅栏的设置方式共有 种。请计算其中满足下述条件的设置方式的个数,并对 取模输出。
条件: 每个区画中恰好包含 个写有 Y 的格子。
输入格式
输入以如下格式从标准输入给出。
输出格式
输出满足条件的栅栏设置方式总数,对 取模。
样例 1
输入
2 3
XYY
YXY
输出
2
样例 2
输入
2 3
XYX
YYY
输出
0
样例 3
输入
2 58
YXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXY
YXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXYXXY
输出
164036797
说明/提示
限制条件
- 是仅由
X和Y组成的长度为 的字符串。
样例解释 1
下面是设置围栏的八种方式。
X Y Y X|Y Y X Y|Y X|Y|Y
| | | |
Y X Y Y|X Y Y X|Y Y|X|Y
X Y Y X|Y Y X Y|Y X|Y|Y
----- -+--- ---+- -+-+-
Y X Y Y|X Y Y X|Y Y|X|Y
例如,如果在第 2 列和第 3 列之间设置一堵围栏,则划分的区画为:
XY
YX
Y
Y
每个区画都正好有两个 Y,因此满足条件。
如果在第 1 行与第 2 行之间以及第 1 列与第 2 列之间设置围栏,则划分的区画为:
X
YY
Y
XY
这些区画中,除第二个外,其余都没有正好两个 Y,因此不满足条件。
样例解释 2
无论如何设置栅栏,都无法满足条件,故答案为 0。
样例解释 3
请输出满足条件的栅栏设置方式总数,对 取模。
由 ChatGPT 4.1 翻译