走迷宫3
2023-08-07 10:45:37
发布于:浙江
include<bits/stdc++.h>
using namespace std;
char a[50][50];
int vis[50][50];
int n,m,sx,sy,fx,fy;
int dx[]={0,0,-1,0,1};
int dy[]={0,-1,0,1,0};
struct node{
int x,y,step;
};
queue<node> q;
void bfs(int x,int y){
node t={x,y,0};
q.push(t);
vis[x][y]=1;
while(!q.empty()){
node s=q.front();
q.pop();
int x=s.x,y=s.y,st=s.step;
for(int i=1;i<=4;i++){
int xx=dx[i]+x;
int yy=dy[i]+y;
int stt=st+1;
if(xx<1||xx>n||yy<1||yy>m) continue;
if(a[xx][yy]=='#') continue;
if(a[xx][yy]>='0'&&a[xx][yy]<='9') stt+=a[xx][yy]-'0';
if(vis[xx][yy]==0 || stt<vis[xx][yy]){
vis[xx][yy]=stt;
node t={xx,yy,stt};
q.push(t);
}
}
}
}
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>a[i][j];
if(a[i][j]=='Z') sx=i,sy=j;
if(a[i][j]=='W') fx=i,fy=j;
}
}
if(sx==fx&&sy==fy){
cout<<0;
return 0;
}
bfs(sx,sy);
if(vis[fx][fy]==0) cout<<"IMPOSSIBLE";
else cout<<vis[fx][fy];
return 0;
}
这里空空如也
有帮助,赞一个