AcWing 1099. 仙岛求药
原题链接
简单
作者:
噷梢
,
2025-04-10 22:43:25
· 福建
,
所有人可见
,
阅读 2
using namespace std;
typedef pair<int,int> PII;
const int N=310;
PII q[N*N];
int d[N][N];
char g[N][N];
int n,m;
int dx[]={0,0,1,-1},dy[]={1,-1,0,0};
int bfs(int x,int y){
int hh=0,tt=-1;
q[++tt]={x,y};
d[x][y]=0;
while(hh<=tt){
auto t=q[hh++];
for(int i=0;i<4;i++){
int a=t.first+dx[i],b=t.second+dy[i];
if(a<0||a>=n||b<0||b>=m)continue;
if(g[a][b]=='#'||d[a][b]!=-1)continue;
if(g[a][b]=='*')return d[t.first][t.second]+1;
d[a][b]=d[t.first][t.second]+1;
q[++tt]={a,b};
}
}
return -1;
}
int main(){
while(cin>>n>>m,n||m){
memset(d,-1,sizeof d);
for(int i=0;i<n;i++)cin>>g[i];
int x,y;
for(int i=0;i<n;i++){
for(int j=0;j<m;j++)
{
if(g[i][j]=='@'){
x=i,y=j;
break;
}
}
}
cout<<bfs(x,y)<<endl;;
}
return 0;
}