题目描述
给定一个N*M方格的迷宫(1<=N,M<=5),迷宫里有T处障碍,障碍处不可通过。给定起点坐标和终点坐标,问能不能从起点坐标走到终点坐标,并要求每个方格最多经过一次。在迷宫中移动有上下左右四种方式,每次只能移动一个方格。输入数据保证起点和终点上都没有障碍。迷宫最左上方的格子坐标为(1,1),最右下方的格子的坐标为(N,M)。
输入格式
第一行三个整数:N、M和T,N为行,M为列,T为障碍总数。
第二行四个整数:起点坐标SX, SY,终点坐标FX, FY。
接下来T行,每行两个整数,为障碍点的坐标。
输出格式
如果能从起点坐标走到终点坐标就输出YES, 否则输出NO。
输入样例1:
4 4 3 1 1 4 4 2 2 3 3 4 1
输出样例1:
YES
输入样例2:
3 3 3 1 1 3 2 2 2 3 1 1 3
输出样例2:
NO
代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
bool vis[6][6],s[6][6] ;
int n,m,sx,sy,fx,fy,t;
bool success;
void dfs(int x,int y){
if(x==fx&&y==fy){
success=1;
return;
}
if(x<1||x>n||y<1||y>m||vis[x][y]==1||s[x][y]==1) return;
vis[x][y]=1;
dfs(x+1,y);
dfs(x-1,y);
dfs(x,y-1);
dfs(x,y+1);
}
int main()
{
cin>>n>>m>>t;
cin>>sx>>sy>>fx>>fy;
for(int i=1;i<=t;i++){
int tx,ty;
cin>>tx>>ty;
s[tx][ty]=1;
}
dfs(sx,sy);
if(success==1)cout<<"YES";
else cout<<"NO";
return 0;
}