AT_abc420_d [ABC420D] Toggle Maze
题目描述
有一个 $H$ 行 $W$ 列的网格。用 $(i,j)$ 表示从上到下第 $i$ 行、从左到右第 $j$ 列的格子。每个格子的状态由字符 $A_{i,j}$ 表示,含义如下:
- `.` :空格子。
- `#` :障碍格子。
- `S` :起始格子。
- `G` :目标格子。
- `o` :开启的门格子。
- `x` :关闭的门格子。
- `?` :开关格子。
高桥可以每次从当前位置移动到相邻的格子(上下左右),前提是该格子不是障碍格子也不是关闭的门格子,每次移动算一次操作。
此外,每当他移动到一个开关格子时,所有开启的门格子会变为关闭的门格子,所有关闭的门格子会变为开启的门格子。
请判断他是否可以从起始格子出发到达目标格子。如果可以,输出所需的最小操作次数;否则输出 $-1$。
输入格式
输入按以下格式从标准输入给出:
> $H$ $W$
> $A_{1,1}A_{1,2}\cdots A_{1,W}$
> $A_{2,1}A_{2,2}\cdots A_{2,W}$
> $\vdots$
> $A_{H,1}A_{H,2}\cdots A_{H,W}$
输出格式
如果高桥可以从起始格子到达目标格子,输出最小操作次数;否则输出 $-1$。
说明/提示
### 样例解释 1
按照 $(1,1) \to (1,2) \to (2,2) \to (1,2) \to (1,3) \to (1,4)$ 的顺序移动,他可以在五次操作内到达目标格子。
### 样例解释 2
无论如何操作,都无法到达目标格子。因此输出 $-1$。
### 数据范围
- $1\le H,W \le 500$
- $H$ 和 $W$ 为整数。
- 每个 $A_{i,j}$ 取值为 `.`、`#`、`S`、`G`、`o`、`x`、`?` 之一。
- $A_{i,j}$ 中 `S` 和 `G` 各出现恰好一次。
由 ChatGPT 4.1 翻译