题目描述
机器猫被困在一个矩形迷宫里。
迷宫可以视为一个 n\times mn×m 矩阵,每个位置要么是空地,要么是墙。机器猫只能从一个空地走到其上、下、左、右的空地。
机器猫初始时位于 (1, 1)(1,1) 的位置,问能否走到 (n, m)(n,m) 位置。
输入格式
第一行,两个正整数 n,mn,m。
接下来 nn 行,输入这个迷宫。每行输入一个长为 mm 的字符串,#
表示墙,.
表示空地。
输出格式
仅一行,一个字符串。如果机器猫能走到 (n, m)(n,m),则输出 Yes
;否则输出 No
。
输入输出样例
输入 #1
3 5 .##.# .#... ...#.
输出 #1
Yes
说明/提示
样例解释
路线如下:(1,1)\to (2,1) \to (3,1) \to (3,2)\to (3,3) \to (2, 3) \to (2, 4) \to (2, 5) \to (3, 5)(1,1)→(2,1)→(3,1)→(3,2)→(3,3)→(2,3)→(2,4)→(2,5)→(3,5)
数据规模与约定
对于 100\%100% 的数据,保证 1 \leq n, m \leq 1001≤n,m≤100,且 (1,1)(1,1) 和 (n, m)(n,m) 均为空地。
代码:
#include<iostream>
using namespace std;
int n,c,m[101][101],b[4][2]= {{-1,0},{1,0},{0,1},{0,-1}},d=0;
char v[101][101];
void dfs(int x,int y) {
if(d==1) return;
if(v[x][y]=='@') {
cout<<"Yes";
d=1;
return;
}
m[x][y]=1;
for(int i=0; i<4; i++) {
int dx=x+b[i][0];
int dy=y+b[i][1];
if(m[dx][dy]!=1&&dx<n&&dx>=0&&dy<c&&dy>=0&&v[dx][dy]!='#') {
dfs(dx,dy);
}
}
}
int main() {
cin>>n>>c;
char a;
for(int i=0; i<n; i++) {
for(int j=0; j<c; j++) {
cin>>v[i][j];
}
}
v[n-1][c-1]='@';
dfs(0,0);
if(d==0) cout<<"No";
return 0;
}