AT_abc308_d [ABC308D] Snuke Maze
题目描述
有一个 $H$ 行 $W$ 列的网格。以下将从上到下第 $i$ 行、从左到右第 $j$ 列的格子记作 $(i, j)$。网格的每个格子上都写有一个小写英文字母,$(i, j)$ 上写的字母等于给定字符串 $S_i$ 的第 $j$ 个字符。
すぬけ君想要通过不断移动到边上相邻的格子,从 $(1, 1)$ 走到 $(H, W)$。他希望所经过的格子(包括起点 $(1, 1)$ 和终点 $(H, W)$)上写的字母,按照经过的顺序依次为 `s` $\rightarrow$ `n` $\rightarrow$ `u` $\rightarrow$ `k` $\rightarrow$ `e` $\rightarrow$ `s` $\rightarrow$ `n` $\rightarrow \dots$,即不断循环 `snuke` 这五个字母。请判断是否存在这样的一条路径。
这里,两个格子 $(i_1, j_1)$ 和 $(i_2, j_2)$ 当且仅当 $|i_1 - i_2| + |j_1 - j_2| = 1$ 时,称为“边上相邻”。
更严格地说,请判断是否存在一个格子序列 $((i_1, j_1), (i_2, j_2), \dots, (i_k, j_k))$,满足以下所有条件:
- $(i_1, j_1) = (1, 1),\ (i_k, j_k) = (H, W)$
- 对所有 $t\ (1 \leq t < k)$,$(i_t, j_t)$ 和 $(i_{t+1}, j_{t+1})$ 边上相邻
- 对所有 $t\ (1 \leq t \leq k)$,$(i_t, j_t)$ 上写的字母等于 `snuke` 的第 $((t-1) \bmod 5) + 1$ 个字母
输入格式
输入按以下格式从标准输入读入。
> $H$ $W$
> $S_1$
> $S_2$
> $\vdots$
> $S_H$
输出格式
如果存在满足题意的路径,输出 `Yes`;否则输出 `No`。
说明/提示
## 限制
- $2 \leq H, W \leq 500$
- $H, W$ 为整数
- $S_i$ 是由小写英文字母组成的长度为 $W$ 的字符串
## 样例解释 1
路径 $(1, 1) \rightarrow (1, 2) \rightarrow (2, 2) \rightarrow (2, 3)$,经过的格子上的字母依次为 `s` $\rightarrow$ `n` $\rightarrow$ `u` $\rightarrow$ `k`,满足条件。
由 ChatGPT 4.1 翻译