标签
深搜 递归 广搜
题目
输入输出
代码
#include<bits/stdc++.h>
using namespace std;
int a[110][110],n,s1,s2,e1,e2,i,j;
int fx[5]={0,0,1,0,-1};
int fy[5]={0,1,0,-1,0};
bool f=false;
void fun(int x,int y)
{
a[x][y]=1;
int tx,ty;
for(i=1;i<=4;i++)
{
tx=x+fx[i];
ty=y+fy[i];
if(tx>=1&&tx<=n&&ty>=1&&ty<=n&&a[tx][ty]==0&&f==false)
{
if(tx==e1&&ty==e2) f=true;
else fun(tx,ty);
}
}
}
int main()
{
cin>>n;
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
cin>>a[i][j];
cin>>s1>>s2>>e1>>e2;
if(a[s1][s2]==1||a[e1][e2]==1) cout<<"NO";
else
{
fun(s1,s2);
if(f==true) cout<<"YES";
else cout<<"NO";
}
return 0;
}