A8036走迷宫——题解
2024-08-25 21:28:27
发布于:湖南
6阅读
0回复
0点赞
#include <bits/stdc++.h>
using namespace std;
//#define int long long
int n,m;
struct node{
int x,y;
int step;
};
queue<node> q;
char mp[5005][5005];
bool vis[5005][5005];
int dx[4]={-1,1,0,0};
int dy[4]={0,0,-1,1};
bool inmp(int x,int y){
return x>=1 && x<=n && y>=1 && y<=m && vis[x][y]==false && mp[x][y]=='.';
}
int ans;
void bfs(int x,int y){
q.push({x,y,0});
vis[x][y]=true;
while(!q.empty()){
node t=q.front();
q.pop();
int cx=t.x;
int cy=t.y;
int cs=t.step;
if(cx==n && cy==m){
ans=cs;
return ;
}
for(int i=0;i<4;i++){
int xx=cx+dx[i];
int yy=cy+dy[i];
if(inmp(xx,yy)==true){
q.push({xx,yy,cs+1});
vis[xx][yy]=true;
}
}
}
}
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>mp[i][j];
}
}
bfs(1,1);
if(vis[n][m]==true){
cout<<ans+1;
}
else{
cout<<"-1";
}
return 0;
}
这里空空如也
有帮助,赞一个