|
本帖最后由 程子 于 2025-1-18 10:54 编辑
#include<bits/stdc++.h>
using namespace std;
long long x=0;
int n=x;
int ha,la,hb,lb;
char ch[110][110];
bool vis[110][110];
int dr[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
struct pos{
int x;
int y;
int step;
};
bool f=false;
void bfs(){
queue<pos>q;
pos p;
p.x=ha;
p.y=la;
p.step=0;
vis[ha][la]=true;
q.push(p);
while(!q.empty()){
p=q.front();
q.pop();
for(int i=0;i<4;i++){
int nx=p.x+dr[0];
int ny=p.y+dr[1];
if(nx>=0&&nx<n&&ny>=0&&ny<n&&ch[nx][ny]=='.'&&!vis[nx][ny]){
vis[nx][ny]=true;
if(nx==hb&&ny==lb){
f=true;
return;
}
pos np;
np.x=nx;
np.y=ny;
np.step=p.step+1;
q.push(np);
}
}
}
}
void dfs(){
bfs();
}
int main(){
int k;
cin>>k;
while(k--){
cin>>n;
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
cin>>ch[j];
}
}
cin>>ha>>la>>hb>>lb;
memset(vis,false,sizeof(vis));
f=false;
if(ch[ha][la]=='#'||ch[hb][lb]=='#'){
cout<<"NO"<<endl;
}else{
dfs();
if(f){
cout<<"YES"<<endl;
}else{
cout<<"NO"<<endl;
}
}
}
return 0;
}
|
|