博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2753:走迷宫
阅读量:4953 次
发布时间:2019-06-12

本文共 1140 字,大约阅读时间需要 3 分钟。

题目链接:http://noi.openjudge.cn/ch0205/2753/ 总时间限制: 1000ms 内存限制: 65536kB
描述
一个迷宫由R行C列格子组成,有的格子里有障碍物,不能走;有的格子是空地,可以走。
给定一个迷宫,求从左上角走到右下角最少需要走多少步(数据保证一定能走到)。只能在水平方向或垂直方向走,不能斜着走。
输入
第一行是两个整数,R和C,代表迷宫的长和宽。( 1<= R,C <= 40)
接下来是R行,每行C个字符,代表整个迷宫。
空地格子用'.'表示,有障碍物的格子用'#'表示。
迷宫左上角和右下角都是'.'。
输出
输出从左上角走到右下角至少要经过多少步(即至少要经过多少个空地格子)。计算步数要包括起点和终点。
样例输入
5 5..####....#.#.##.#.##.#..
样例输出
9

算法分析:

迷宫问题的最短路径,广搜。

1 #include
2 #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

 

转载于:https://www.cnblogs.com/huashanqingzhu/p/7267752.html

你可能感兴趣的文章
Strict Standards: Only variables should be passed by reference
查看>>
hiho_offer收割18_题解报告_差第四题
查看>>
AngularJs表单验证
查看>>
静态方法是否属于线程安全
查看>>
fegin 调用源码分析
查看>>
Linux的基本命令
查看>>
02号团队-团队任务3:每日立会(2018-12-05)
查看>>
SQLite移植手记1
查看>>
C# windows程序应用与JavaScript 程序交互实现例子
查看>>
HashMap详解
查看>>
Adobe Scout 入门
查看>>
51nod 1247可能的路径
查看>>
js05-DOM对象二
查看>>
mariadb BINLOG_FORMAT = STATEMENT 异常
查看>>
C3P0 WARN: Establishing SSL connection without server's identity verification is not recommended
查看>>
iPhone在日本最牛,在中国输得最慘
查看>>
动态方法决议 和 消息转发
查看>>
WPF自定义搜索框代码分享
查看>>
js 基础拓展
查看>>
SpringBoot访问html访问不了的问题
查看>>