1006: Hero In Maze

时间限制: 1000 Sec  内存限制: 64 MB
提交: 417  解决: 80
[提交][状态][讨论版][命题人:外部导入]

题目描述

500年前,Jesse是我国最卓越的剑客。他英俊潇洒,而且机智过人^_^。
突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中。Jesse听说这个消息已经是两天以后了,他知道公主在迷宫中还能坚持T天,他急忙赶到迷宫,开始到处寻找公主的下落。 时间一点一点的过去,Jesse还是无法找到公主。最后当他找到公主的时候,美丽的公主已经死了。从此Jesse郁郁寡欢,茶饭不思,一年后追随公主而去了。T_T 500年后的今天,Jesse托梦给你,希望你帮他判断一下当年他是否有机会在给定的时间内找到公主。
他会为你提供迷宫的地图以及所剩的时间T。请你判断他是否能救出心爱的公主。

输入

题目包括多组测试数据。 每组测试数据以三个整数N,M,T(0<n, m≤20, t>0)开头,分别代表迷宫的长和高,以及公主能坚持的天数。 紧接着有M行,N列字符,由".","*","P","S"组成。其中 "." 代表能够行走的空地。 "*" 代表墙壁,Jesse不能从此通过。 "P" 是公主所在的位置。 "S" 是Jesse的起始位置。 每个时间段里Jesse只能选择“上、下、左、右”任意一方向走一步。 输入以0 0 0结束。

输出

如果能在规定时间内救出公主输出“YES”,否则输出“NO”。

样例输入

  1. 4 4 10
  2. ....
  3. ....
  4. ....
  5. S**P
  6. 0 0 0

样例输出

  1. YES
  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<queue>
  5. using namespace std;
  6. char maze[25][25];
  7. int vis[25][25];
  8. int dir[4][2] = {{1,0}, {-1,0},{0,1},{0,-1}};
  9. int n, ans, num, m, c, d;
  10. struct point
  11. {
  12. int x;
  13. int y;
  14. int step;
  15. };
  16. int bfs(int x, int y)
  17. {
  18. queue<point> p;
  19. struct point now, t, start;
  20. start.x = x;
  21. start.y = y;
  22. start.step = 0;
  23. vis[x][y] = 1;
  24. p.push(start);
  25. while(!p.empty())
  26. {
  27. int i, a, b;
  28. t = p.front();
  29. if(t.x == c && t.y == d)
  30. {
  31. while(!p.empty())
  32. p.pop();
  33. return t.step;
  34. }
  35. for(i = 0; i < 4; ++i)
  36. {
  37. a = t.x + dir[i][0];
  38. b = t.y + dir[i][1];
  39. if(a >= 1 && a <= m && b >= 1 && b <= n && vis[a][b] == 0)
  40. {
  41. vis[a][b] = 1;
  42. now.step = t.step + 1;
  43. now.x = a;
  44. now.y = b;
  45. p.push(now);
  46. }
  47. }
  48. p.pop();
  49. }
  50. while(!p.empty())
  51. p.pop();
  52. return 1000000000;
  53. }
  54. int main()
  55. {
  56. while(~scanf("%d%d%d", &n, &m, &num))
  57. {
  58. if(n == 0 && m == 0 && num == 0)
  59. break;
  60. int i, j, a, b;
  61. memset(maze, 0, sizeof(maze));
  62. memset(vis, 0, sizeof(vis));
  63. for(i = 1; i <= m; ++i)
  64. {
  65. getchar(); //!!!!!!
  66. for(j = 1; j <= n; ++j)
  67. {
  68. scanf("%c", &maze[i][j]);
  69. if(maze[i][j] == 'S')
  70. {
  71. a = i;
  72. b = j;
  73. }
  74. else if(maze[i][j] == 'P')
  75. {
  76. c = i;
  77. d = j;
  78. }
  79. else if(maze[i][j] == '*')
  80. vis[i][j] = 1;
  81. }
  82.  
  83. }
  84. ans = bfs(a, b);
  85. if(ans > num)
  86. printf("NO\n");
  87. else
  88. printf("YES\n");
  89. }
  90. return 0;
  91. }

  

  1.  

1006: Hero In Maze的更多相关文章

  1. YTU 1006: Hero In Maze

    1006: Hero In Maze 时间限制: 1000 Sec  内存限制: 64 MB 提交: 72  解决: 22 题目描述 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人 ...

  2. Hero In Maze

    Hero In Maze 时间限制(普通/Java):1000MS/10000MS          执行内存限制:65536KByte 描写叙述 500年前,Jesse是我国最卓越的剑客. 他英俊潇 ...

  3. TZOJ 3305 Hero In Maze II(深搜)

    描述 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^.突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了,他急忙赶到迷宫,开 ...

  4. Hero In Maze(BFS广搜)

    Description 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^.突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了, ...

  5. TOJ 1005 Hero In Maze (深搜)

    描述 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^. 突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了,他知道公主在迷宫 ...

  6. 【TOJ 3305】Hero In Maze II

    描述 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^.突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了,他急忙赶到迷宫,开 ...

  7. 3305: Hero In Maze II (优先队列+bfs)

    Description 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^.突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了, ...

  8. ACM-Hero In Maze

                                                   Hero In Maze 时间限制(普通/Java):1000MS/10000MS          运行 ...

  9. 杭电ACM分类

    杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze ...

随机推荐

  1. vue-cli构建的项目打包出现里面的js,css缺少dist路径

    转载 https://www.cnblogs.com/wanf/p/7871787.html

  2. 2018.6.1学习CSS5里顺丰盒子小问题

    在制作下面这样的小盒子时 编写的代码 首先要对li元素设置浮动. 在设置这个li元素下面的a元素时, 因为没有转行内块,inline-block,结果显示出来的页面,鼠标在经过这个选择时(:hover ...

  3. PlayMaker Get Parent 拿到父物体

    这里是拿到自己的父物体,然后存储到Parent这个GameObject变量里. 然后在Parent那个位置生成一个Coin,也就是在父物体那生成一个Coin.

  4. vue-cli生成的重要代码详解

    安装好vue-cli之后,我们可以在package.json中看到下面所示: { // 项目名称 "name": "myvue", // 项目版本 " ...

  5. 最新版本dede与discuz通过ucenter完美整合

    人合租虚拟主机.然后到相关的官方网站上面下载相关的程序,我下载的是DedeCmsV5.7-GBK+Discuz_X2_RC_SC_GBK+UCenter_1.6.0_SC_GBK这个程序组合.涉及到怎 ...

  6. HDU 4357——String change——————【规律题】

    String change Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

  7. AngularJS directive 动态 template

    app.directive('testwindow', function() { return { restrict : 'E', template: '<ng-include src=&quo ...

  8. 导出CSV

    public FileResult ExportExcel() { var sbHtml = new StringBuilder(); sbHtml.Append("<table bo ...

  9. JS条件语句优化

    1.对多个条件使用Array.includes eg: function test(fruit){                                                    ...

  10. org.springframework.beans.factory.BeanNotOfRequiredTypeException

    写一个代码:关于Spring Bean的装配.基于annotation实现的范例代码. 出现了错误: 十一月 14, 2018 4:51:01 下午 org.springframework.conte ...