算法提高 学霸的迷宫  
时间限制:1.0s   内存限制:256.0MB
    
问题描述
  学霸抢走了大家的作业,班长为了帮同学们找回作业,决定去找学霸决斗。但学霸为了不要别人打扰,住在一个城堡里,城堡外面是一个二维的格子迷宫,要进城堡必须得先通过迷宫。因为班长还有妹子要陪,磨刀不误砍柴功,他为了节约时间,从线人那里搞到了迷宫的地图,准备提前计算最短的路线。可是他现在正向妹子解释这件事情,于是就委托你帮他找一条最短的路线。
输入格式
  第一行两个整数n, m,为迷宫的长宽。
  接下来n行,每行m个数,数之间没有间隔,为0或1中的一个。0表示这个格子可以通过,1表示不可以。假设你现在已经在迷宫坐标(1,1)的地方,即左上角,迷宫的出口在(n,m)。每次移动时只能向上下左右4个方向移动到另外一个可以通过的格子里,每次移动算一步。数据保证(1,1),(n,m)可以通过。
输出格式
  第一行一个数为需要的最少步数K。
  第二行K个字符,每个字符∈{U,D,L,R},分别表示上下左右。如果有多条长度相同的最短路径,选择在此表示方法下字典序最小的一个。
样例输入
Input Sample 1:
3 3
001
100
110

Input Sample 2:
3 3
000
000
000

样例输出
Output Sample 1:
4
RDRD

Output Sample 2:
4
DDRR

数据规模和约定
  有20%的数据满足:1<=n,m<=10
  有50%的数据满足:1<=n,m<=50
  有100%的数据满足:1<=n,m<=500。
 
  1. #include <iostream>
  2. #include <algorithm>
  3. #include <cstdlib>
  4. #include <utility>
  5. #include <map>
  6. #include <cstdio>
  7. #include <queue>
  8. using namespace std;
  9. const int maxn = + ;
  10. const int INF = ;
  11. typedef pair<int,int> P;
  12. // D(下), L(左), R(右), U(上)
  13. int dir[][] = { {, }, {, -}, {, }, {-, }};
  14. char dir_c[] = {'D', 'L', 'R', 'U'};
  15. int row, col; //行列
  16. char maze[maxn][maxn]; //表示迷宫的字符串的数组
  17. int d[maxn][maxn]; //到各个位置的最短距离的数组
  18. string Min; //U,D,L,R
  19. queue<P> que;
  20. void input();
  21. bool judge(int r, int c);
  22. int BFS();
  23. void input()
  24. {
  25. scanf("%d%d", &row, &col);
  26. for (int i = ; i < row; i++) {
  27. for (int j = ; j < col; j++) {
  28. cin >> maze[i][j];
  29. }
  30. }
  31. //所有位置初始化
  32. for (int i = ; i < row; i++) {
  33. for (int j = ; j < col; j++) {
  34. d[i][j] = INF;
  35. }
  36. }
  37. }
  38. bool judge(int r, int c)
  39. {
  40. return (r >= && r < row) && (c >= && c < col)
  41. && (maze[r][c] != ''); //可走
  42. }
  43. int BFS()
  44. {
  45. //将起点假如队列, 并把这一地点的距离设置为 0
  46. que.push(P(, ));
  47. queue<string> path;
  48. path.push("");
  49. d[][] = ;
  50. Min = "";
  51. while (!que.empty())
  52. {
  53. P p = que.front(); que.pop();
  54. string t = path.front(); path.pop();
  55. if (p.first == row - && p.second == col - ) {
  56. Min = t; //因为我的方向就是按照字典序 DLRU,所以这时候形成最短路线的路径就是按照字典序最小的路线!
  57. break;
  58. }
  59. for (int i = ; i < ; i++) {
  60. //移动之后的位置为(nx,ny)
  61. int nx = p.first + dir[i][], ny = p.second + dir[i][];
  62. //可以走,且尚未访问(d[nv][ny]==INF
  63. if (judge(nx, ny) && d[nx][ny] == INF) {
  64. //加入到队列,并且到该位置的距离确定为到p的距离+1
  65. que.push(P(nx, ny));
  66. path.push(t + dir_c[i]); //这里数据结构组织的并不好,我应该一开始就把路径和位置组合成结构体,会更方便
  67. d[nx][ny] = d[p.first][p.second] + ; //因为是的方向就是按照 DLRU字典序遍历,所以不需要有什么额外的判断,只需要和行走路线
  68. maze[nx][ny] = ''; //一起出队,入队就可以了!
  69. }
  70. }
  71. }
  72. return d[row - ][col - ];
  73. }
  74. void solve()
  75. {
  76. input();
  77. int res = BFS();
  78. printf("%d\n%s\n", res, Min.c_str());
  79. }
  80. int main()
  81. {
  82. solve();
  83. return ;
  84. }

蓝桥杯 算法提高 学霸的迷宫 经典BFS问题的更多相关文章

  1. Java实现 蓝桥杯 算法提高 学霸的迷宫

    算法提高 学霸的迷宫 时间限制:1.0s 内存限制:256.0MB 问题描述 学霸抢走了大家的作业,班长为了帮同学们找回作业,决定去找学霸决斗.但学霸为了不要别人打扰,住在一个城堡里,城堡外面是一个二 ...

  2. 算法笔记_107:蓝桥杯练习 算法提高 学霸的迷宫(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 学霸抢走了大家的作业,班长为了帮同学们找回作业,决定去找学霸决斗.但学霸为了不要别人打扰,住在一个城堡里,城堡外面是一个二维的格子迷宫,要 ...

  3. 问题 1936: [蓝桥杯][算法提高VIP]最大乘积

    问题 1936: [蓝桥杯][算法提高VIP]最大乘积 时间限制: 1Sec 内存限制: 128MB 提交: 77 解决: 16 题目描述 对于n个数,从中取出m个数,如何取使得这m个数的乘积最大呢? ...

  4. 蓝桥杯 算法提高 11-1实现strcmp函数 (JAVA方法)

    蓝桥杯 算法提高 11-1实现strcmp函数 (JAVA方法) 首先这不是一个多难的题,但是网上的我没怎么找到有Java的代码,基本全都是c语言的,小编是个小白,如果有不对的地方请联系小编 问题描述 ...

  5. 蓝桥杯 算法提高 金属采集 [ 树形dp 经典 ]

    传送门 算法提高 金属采集 时间限制:1.0s   内存限制:256.0MB     锦囊1   锦囊2   锦囊3   问题描述 人类在火星上发现了一种新的金属!这些金属分布在一些奇怪的地方,不妨叫 ...

  6. Java实现 蓝桥杯 算法提高 进攻策略加强(暴力)

    试题 算法提高 进攻策略加强 问题描述 植物大战僵尸这款游戏中,还有一个特别的玩儿法:玩家操纵僵尸进攻植物. 首先,僵尸有m种(每种僵尸都是无限多的),玩家可以选择合适的僵尸来进攻.使用第i种僵尸需要 ...

  7. Java实现 蓝桥杯 算法提高 小X的购物计划

    试题 算法提高 小X的购物计划 问题描述 小X打算去超市shopping.小X没什么钱,只有N元.超市里有M种物品,每种物品都需要money,在小X心中有一个重要度.有的物品有无限件,有的物品只有几件 ...

  8. 蓝桥杯算法提高 P1001(大数乘法)

      算法提高 P1001   时间限制:1.0s   内存限制:256.0MB   当两个比较大的整数相乘时,可能会出现数据溢出的情形.为避免溢出,可以采用字符串的方法来实现两个大数之间的乘法. 具体 ...

  9. Java实现 蓝桥杯 算法提高 判断名次

    算法提高 判断名次 时间限制:1.0s 内存限制:256.0MB 问题描述 某场比赛过后,你想要知道A~E五个人的排名是什么,于是要求他们每个人说了一句话.(经典的开头---_-!)得了第1名的人23 ...

随机推荐

  1. 【CSAPP笔记】10. 代码优化

    写程序的主要目标是使它在所有可能的情况下都能正确运行(bug free),一个运行得很快但有 bug 的程序是毫无用处的.在 bug free 的基础上,程序员必须写出清晰简洁的代码,这样做是为了今后 ...

  2. STM32F103 CAN中断发送功能的再次讨论

    转自:http://yiyutingmeng.blog.163.com/blog/static/124258578201191584629146/ 我在之前的一篇博客日志中,写过关于CAN发送功能如何 ...

  3. Mongodb 分片操作实战

    由于生产环境中一般使用zoomkeeper做config节点的仲裁节点,zoomkeeper会在三个config节点中挑选出一台作为主config节点.且mongos节点一般是两个节点,必须做高可用, ...

  4. 10.13课堂Scrum站立会议

    项目名称:C#实现的连连看游戏 小组名称:计信F4 开会时间 :2016年10月11日 20:20~20:40 组长:张政 成员:张金生,武志远,李泉 内容: 昨日已完成: 张政:构建基础逻辑,实现游 ...

  5. Python入门:学会创建并调用函数

    这是关于Python的第4篇文章,主要介绍下如何创建并调用函数. print():是打印放入对象的函数 len():是返回对象长度的函数 input():是让用户输入对象的函数 ... 简单来说,函数 ...

  6. dbms_sqltune.report_sql_monitor 自动调优

    --创建 dbms_sqltune.create_tuning_task ; --执行 dbms_sqltune.execute_tuning_task; --产看创建的task 和 status S ...

  7. scala 有 + 运算符吗? - 03

    scala 有运算符吗? 答案是没有. package com.msym /** * Created by ACER on 2017/7/4. */ object Demo { def main(ar ...

  8. mock测试SpringMVC controller报错

    使用mock测试Controller时报错如下 java.lang.NoClassDefFoundError: javax/servlet/SessionCookieConfig at org.spr ...

  9. 使用SQLyog连接MySQL数据库

    [学习笔记]使用SQLyog连接MySQL数据库 一.使用SQLyog创建数据库用来管理学生信息 复制代码 1 #创建数据库student  2 DROP DATABASE IF EXISTS Mys ...

  10. hdu3712 Detector Placement

    题意:给一束激光,一个三棱柱,三棱柱会折射光,问这束激光最终是否会和y = 0相交: 分析:模拟题,为了方便处理折射角,事先求出每条边的向内和向外的法向量: findpoint : 找第一交点 ste ...