迷宫最近出口题解
2023-08-17 20:58:55
发布于:广东
迷宫最近出口:
#include<iostream>
#include<cstring>
#include<queue>
using namespace std;
int n,m,vis[2005][2005],a[2005][2005];
int dx[4]={1,-1,0,0};
int dy[4]={0,0,1,-1};
struct node{
int x,y;
};
queue<node> que;
void bfs(){
while(!que.empty()){
node n1=que.front();
que.pop();
for(int i=0;i<4;i++){
int xx=n1.x+dx[i];
int yy=n1.y+dy[i];
if(xx>=0&&xx<n&&yy>=0&&yy<m&&a[xx][yy]==0&&vis[xx][yy]==-1){
que.push({xx,yy});
vis[xx][yy]=vis[n1.x][n1.y]+1;
}
}
}
}
int main(){
memset(vis,-1,sizeof vis);
cin>>n>>m;
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
cin>>a[i][j];
}
}
int q,x1,y1,minn=1e9;
cin>>q;
while(q--){
cin>>x1>>y1;
vis[x1][y1]=0;
que.push({x1,y1});
}
bfs();
cin>>q;
while(q--){
cin>>x1>>y1;
if(vis[x1][y1]==-1){
continue;
}
minn=min(minn,vis[x1][y1]);
}
cout<<minn;
return 0;
}
这里空空如也
有帮助,赞一个