题目
题目描述
当你站在一个迷宫里的时候,往往会被错综复杂的道路弄得失去方向感,如果你能得到迷宫地图,事情就会变得非常简单。
假设你已经得到了一个n*m的迷宫的图纸,请你找出从起点到出口的最短路。输入
第一行是两个整数n和m(1≤n,m≤100),表示迷宫的行数和列数。
接下来n行,每行一个长为m的字符串,表示整个迷宫的布局。字符‘.’表示空地,‘#’表示墙,‘S’表示起点,‘T’表示出口。输出
输出从起点到出口最少需要走的步数。
样例输入
3 3 S#T .#. ...样例输出
6
代码
#include <bits/stdc++.h>
using namespace std;
char s[200][200];
int n,m;
struct Point{
int x,y,step;
}p[10000],ts,tt;
int dir[4][2]={{0,1},{0,-1},{-1,0},{1,0}};
int head=1, tail=0,used[200][200];
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>s[i][j];
if(s[i][j]=='S'){
ts.x=i;ts.y=j;ts.step=1;
}
if(s[i][j]=='T'){
tt.x=i;tt.y=j;tt.step=1;
}
}
}
//BFS
tail++;
p[tail]=ts;
used[ts.x][ts.y]=1;
while(head<=tail){
Point u=p[head++];
for(int i=0;i<4;i++){
Point v;
v.x=u.x+dir[i][0];
v.y=u.y+dir[i][1];
v.step=u.step+1;
if(v.x<1||v.x>n||v.y<1||v.y>m) continue;
if(used[v.x][v.y]==1) continue;
if(s[v.x][v.y]=='#') continue;
if(v.x==tt.x&&v.y==tt.y){
cout<<v.step-1;
return 0;
}
tail++;
p[tail]=v;
used[v.x][v.y]=1;
}
}
}