题目描述
机器猫被困在一个矩形迷宫里。
迷宫可以视为一个 𝑛×𝑚 矩阵,每个位置要么是空地,要么是墙。机器猫只能从一个空地走到其上、下、左、右的空地。
机器猫初始时位于 (1,1) 的位置,问能否走到 (𝑛,𝑚) 位置。
输入格式
第一行,两个正整数 𝑛,𝑚。
接下来 𝑛n 行,输入这个迷宫。每行输入一个长为 𝑚的字符串,#
表示墙,.
表示空地。
输出格式
仅一行,一个字符串。如果机器猫能走到 (𝑛,𝑚),则输出 Yes
;否则输出 No
。
输入输出样例
输入#1 输出#1
3 5 Yes .##.# .#... ...#.
思路
这道题是很典型的深度优先搜索(DFS)板子。
思路我在上一篇博客讲过了,有想看可以点以下链接。
洛谷题目解析之P1605——迷宫(附带DFS算法解析)-CSDN博客
但这道题在深搜的板子上还要加一个终点判定,也就是在判断终点的时候加一个falg。
bool falg;
/*
-----------------------------------------------------
*/
void dfs(int x,int y){
if(x==fx&&y==fy){
falg=1;
}
}
所以代码如下。
#include<iostream>
using namespace std;
int n,m;
char map[50][50];
bool vis[50][50];
bool falg;
int dir[4][2]={0,1,1,0,0,-1,-1,0};
bool check(int nx,int ny){
return nx>=1&&nx<=n&&ny>=1&&ny<=m;
}
void dfs(int x,int y){
if(x==n&&y==m){
falg=true;
return;
}
vis[x][y]=true;
for(int i=0;i<4;i++){
int nx=x+dir[i][0];
int ny=y+dir[i][1];
if(check(nx,ny)&&vis[nx][ny]==false&&map[nx][ny]!='#'){
dfs(nx,ny);
}
}
}
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>map[i][j];
}
}
dfs(1,1);
if(falg==true)cout<<"Yes";
else cout<<"N0";
return 0;
}
代码经供参考(有一处小错误,不能照抄哦!),记得点赞!^_^