- 题目链接:http://noi.openjudge.cn/ch0205/2753/ 总时间限制: 1000ms 内存限制: 65536kB
- 描述
- 一个迷宫由R行C列格子组成,有的格子里有障碍物,不能走;有的格子是空地,可以走。 给定一个迷宫,求从左上角走到右下角最少需要走多少步(数据保证一定能走到)。只能在水平方向或垂直方向走,不能斜着走。 输入
- 第一行是两个整数,R和C,代表迷宫的长和宽。( 1<= R,C <= 40) 接下来是R行,每行C个字符,代表整个迷宫。 空地格子用'.'表示,有障碍物的格子用'#'表示。 迷宫左上角和右下角都是'.'。 输出
- 输出从左上角走到右下角至少要经过多少步(即至少要经过多少个空地格子)。计算步数要包括起点和终点。 样例输入
-
5 5..####....#.#.##.#.##.#..
样例输出 -
9
算法分析:
迷宫问题的最短路径,广搜。
1 #include2 #include 3 #include 4 using namespace std; 5 struct obj 6 { 7 int x,y,step;//step表示从出发点到达(i,j)需要的步数 . 8 }; 9 10 int R,C;11 char map[42][42];12 queue q;13 struct obj Start,End;14 15 int dx[4]={-1,0,1,0};//上右下左 16 int dy[4]={ 0,1,0,-1};17 void BFS();18 19 int main(int argc, char *argv[])20 {21 //freopen("2753.in","r",stdin);22 int i,j;23 char c;24 25 scanf("%d%d",&R,&C);//getchar();//吸收回车 26 while ((c = getchar()) != EOF && c != '\n');27 //不停地使用getchar()获取缓冲中字符,直到获取的c是“\n”或文件结尾符EOF为止28 for(i=0;i =0&&txx =0&&tyy