AT_abc348_d [ABC348D] Medicines on Grid

题目描述

有一个 $H$ 行 $W$ 列的网格。自上而下第 $i$ 行,自左而右第 $j$ 列的格子用 $(i, j)$ 表示。每个格子的状态由字符 $A_{i,j}$ 表示,含义如下: - `.` :空格。 - `#` :障碍物。 - `S` :空格且为起点。 - `T` :空格且为终点。 高桥君可以从当前格子向上下左右相邻的空格移动,每移动一次消耗 $1$ 点能量。但当能量为 $0$ 时无法移动,也不能移动到网格外。 网格中共有 $N$ 个药品。第 $i$ 个药品位于空格 $(R_i, C_i)$,使用后能量会**变为 $E_i$**。注意,能量不一定会增加。高桥君可以在自己所在的格子使用药品,使用后药品消失。 高桥君一开始在起点,能量为 $0$,他想移动到终点。请判断是否可能。

输入格式

输入按以下格式从标准输入给出。 > $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}$ > $N$ > $R_1$ $C_1$ $E_1$ > $R_2$ $C_2$ $E_2$ > $\vdots$ > $R_N$ $C_N$ $E_N$

输出格式

如果高桥君可以从起点移动到终点,输出 `Yes`,否则输出 `No`。

说明/提示

## 限制条件 - $1 \leq H, W \leq 200$ - $A_{i,j}$ 只可能是 `.`, `#`, `S`, `T` 之一。 - `S` 和 `T` 在 $A_{i,j}$ 中各恰好出现一次。 - $1 \leq N \leq 300$ - $1 \leq R_i \leq H$ - $1 \leq C_i \leq W$ - 如果 $i \neq j$,则 $(R_i, C_i) \neq (R_j, C_j)$ - $A_{R_i, C_i}$ 不是 `#`。 - $1 \leq E_i \leq HW$ ## 样例解释 1 例如,可以按如下方式到达终点: - 使用药品 $1$,能量变为 $3$。 - 移动到 $(1, 2)$,能量变为 $2$。 - 移动到 $(1, 3)$,能量变为 $1$。 - 使用药品 $2$,能量变为 $5$。 - 移动到 $(2, 3)$,能量变为 $4$。 - 移动到 $(3, 3)$,能量变为 $3$。 - 移动到 $(3, 4)$,能量变为 $2$。 - 移动到 $(4, 4)$,能量变为 $1$。 在这个移动过程中,$(2, 3)$ 也有药品,但如果使用它则无法到达终点。 ## 样例解释 2 高桥君无法从起点移动。 由 ChatGPT 4.1 翻译