A83472.Medicines on Grid
普及/提高-
通过率:0%
时间限制:1.00s
内存限制:128MB
题目描述
有一个 H 行 W 列的网格。自上而下第 i 行,自左而右第 j 列的格子用 (i,j) 表示。每个格子的状态由字符 Ai,j 表示,含义如下:
.:空格。#:障碍物。S:空格且为起点。T:空格且为终点。
高桥君可以从当前格子向上下左右相邻的空格移动,每移动一次消耗 1 点能量。但当能量为 0 时无法移动,也不能移动到网格外。
网格中共有 N 个药品。第 i 个药品位于空格 (Ri,Ci),使用后能量会变为 Ei。注意,能量不一定会增加。高桥君可以在自己所在的格子使用药品,使用后药品消失。
高桥君一开始在起点,能量为 0,他想移动到终点。请判断是否可能。
输入格式
输入按以下格式从标准输入给出。
H W
A1,1 A1,2 ⋯ A1,W
A2,1 A2,2 ⋯ A2,W
⋮
AH,1 AH,2 ⋯ AH,W
N
R1 C1 E1
R2 C2 E2
⋮
RN CN EN
输出格式
如果高桥君可以从起点移动到终点,输出 Yes,否则输出 No。
输入输出样例
输入#1
4 4 S... #..# #... ..#T 4 1 1 3 1 3 5 3 2 1 2 3 1
输出#1
Yes
输入#2
2 2 S. T. 1 1 2 4
输出#2
No
说明/提示
限制条件
- 1≤H,W≤200
- Ai,j 只可能是
.,#,S,T之一。 S和T在 Ai,j 中各恰好出现一次。- 1≤N≤300
- 1≤Ri≤H
- 1≤Ci≤W
- 如果 i=j,则 (Ri,Ci)=(Rj,Cj)
- ARi,Ci 不是
#。 - 1≤Ei≤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
高桥君无法从起点移动。