#include<bits/stdc++.h>
using namespace std;
int n;
int ha,la,hb,lb;
int mg[110][110];
bool pathFound =false;
int fx[5]={0,0,1,0,-1};
int fy[5]={0,1,0,-1,0};
void dfs(int x,int y){
mg[x][y]=1;
int tx,ty;
for(int i=1;i<=4;i++){
tx=x+fx[i];
ty=y+fy[i];
if(tx>=1&&tx<=n&&ty>=1&&ty<=n&&mg[tx][ty]==0){
if(tx==hb&&ty==lb){
pathFound=true;
}else{
dfs(tx,ty);
}
}
}
}
int main(){
cin>>n;
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
cin>>mg[i][j];
}
}
cin>>ha>>la>>hb>>lb;
if(mg[ha][la]==1 || mg[hb][lb]==1){
cout<<"NO";
}else{
dfs(ha,la);
if(pathFound){
cout<<"YES";
}else{
cout<<"NO";
}
}
return 0;
}
CSPOJ1430: 【基础】迷宫出口
最新推荐文章于 2024-10-15 19:28:18 发布