胜利大逃亡

Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 21449    Accepted Submission(s): 8442

Problem Description
Ignatius被魔王抓走了,有一天魔王出差去了,这可是Ignatius逃亡的好机会.

魔王住在一个城堡里,城堡是一个A*B*C的立方体,可以被表示成A个B*C的矩阵,刚开始Ignatius被关在(0,0,0)的位置,离开城堡的门在(A-1,B-1,C-1)的位置,现在知道魔王将在T分钟后回到城堡,Ignatius每分钟能从一个坐标走到相邻的六个坐标中的其中一个.现在给你城堡的地图,请你计算出Ignatius能否在魔王回来前离开城堡(只要走到出口就算离开城堡,如果走到出口的时候魔王刚好回来也算逃亡成功),如果可以请输出需要多少分钟才能离开,如果不能则输出-1.

 
Input
输入数据的第一行是一个正整数K,表明测试数据的数量.每组测试数据的第一行是四个正整数A,B,C和T(1<=A,B,C<=50,1<=T<=1000),它们分别代表城堡的大小和魔王回来的时间.然后是A块输入数据(先是第0块,然后是第1块,第2块......),每块输入数据有B行,每行有C个正整数,代表迷宫的布局,其中0代表路,1代表墙.(如果对输入描述不清楚,可以参考Sample Input中的迷宫描述,它表示的就是上图中的迷宫)

特别注意:本题的测试数据非常大,请使用scanf输入,我不能保证使用cin能不超时.在本OJ上请使用Visual C++提交.

 
Output
对于每组测试数据,如果Ignatius能够在魔王回来前离开城堡,那么请输出他最少需要多少分钟,否则输出-1.

 
Sample Input
1
3 3 4 20
0 1 1 1
0 0 1 1
0 1 1 1
1 1 1 1
1 0 0 1
0 1 1 1
0 0 0 0
0 1 1 0
0 1 1 0
 
Sample Output
11
 
Author
Ignatius.L
 
Recommend

Ignatius.L

题意:有一个人要在魔王回来之前逃出城堡。1表示墙,0表示路。t表示魔王回来的时间。

感想:这题比较坑的一点是起点可以是墙,但是人能走出。而终点也可以是墙,那自然就走不出了,但是要判断。

剪枝:如果终点是门或者从起点到终点的最短时间都大于t ,直接输出 -1。

代码:

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<cstring>
  4. #include<queue>
  5. using namespace std;
  6.  
  7. int maps[55][55][55];
  8. int a,b,c,t;
  9. struct node
  10. {
  11. int x,y,z;
  12. int steps;
  13. }start;
  14. int dx[]={0,0,0,0,-1,1};
  15. int dy[]={0,0,-1,1,0,0};
  16. int dz[]={-1,1,0,0,0,0};
  17.  
  18. bool in(node &now)
  19. {
  20. if(now.x>=1&&now.x<=a&&now.y>=1&&now.y<=b&&now.z>=1&&now.z<=c)
  21. return true;
  22. else return false;
  23. }
  24.  
  25. int bfs()
  26. {
  27. queue<node> q;
  28. while(!q.empty())
  29. q.pop();
  30. q.push(start);
  31. maps[start.x][start.y][start.z]=1;
  32. node cur,next;
  33. while(!q.empty())
  34. {
  35. cur=q.front();
  36. q.pop();
  37. if(cur.x==a&&cur.y==b&&cur.z==c&&cur.steps<=t)
  38. return cur.steps;
  39. for(int i=0;i<6;i++)
  40. {
  41. next.x=cur.x+dx[i];
  42. next.y=cur.y+dy[i];
  43. next.z=cur.z+dz[i];
  44. if(in(next)&&next.x==a&&next.y==b&&next.z==c&&(cur.steps+1)<=t)
  45. return cur.steps+1;
  46. if(in(next)&&maps[next.x][next.y][next.z]==0)
  47. {
  48. next.steps=cur.steps+1;
  49. //printf("test: %d %d %d %d\n",next.x,next.y,next.z,next.steps);
  50. maps[next.x][next.y][next.z]=1;
  51. q.push(next);
  52. }
  53. }
  54. }
  55. return -1;
  56. }
  57.  
  58. int main()
  59. {
  60. int n,i,j,k,flag;
  61. scanf("%d",&n);
  62. getchar();
  63. while(n--)
  64. {
  65. scanf("%d%d%d%d",&a,&b,&c,&t);
  66. getchar();
  67. for(i=1;i<=a;i++)
  68. {
  69. for(j=1;j<=b;j++)
  70. for(k=1;k<=c;k++)
  71. {
  72. scanf("%d",&maps[i][j][k]);
  73. }
  74. }
  75. start.x=start.y=start.z=1;
  76. start.steps=0;
  77. if(a+b+c-3>t||maps[a][b][c]==1) //剪枝
  78. flag=-1;
  79. else
  80. flag=bfs();
  81. printf("%d\n",flag);
  82. }
  83. return 0;
  84. }
  85.  
  86. //AC
  87.  
  88. /*
  89.  
  90. 1
  91. 3 3 4 20
  92. 0 1 1 1
  93. 0 0 1 1
  94. 0 1 1 1
  95. 1 1 1 1
  96. 1 0 0 1
  97. 0 1 1 1
  98. 0 0 0 0
  99. 0 1 1 0
  100. 0 1 1 0
  101.  
  102. */

8752232

2013-07-29 14:03:48

Accepted

515MS

896K

1830 B

C++

hdu 1253 胜利大逃亡 (三维简单bfs+剪枝)的更多相关文章

  1. hdu 1253 胜利大逃亡(简单题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1253 题目大意:在所给的时间能顺利离开城堡. #include <iostream> #i ...

  2. [ACM] hdu 1253 胜利大逃亡 (三维BFS)

    胜利大逃亡 Problem Description Ignatius被魔王抓走了,有一天魔王出差去了,这但是Ignatius逃亡的好机会. 魔王住在一个城堡里,城堡是一个A*B*C的立方体,能够被表示 ...

  3. hdu 1253:胜利大逃亡(基础广搜BFS)

    胜利大逃亡 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  4. HDU 1253 胜利大逃亡 NYOJ 523【BFS】

    胜利大逃亡 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  5. HDU 1429 胜利大逃亡(续)(bfs+状态压缩,很经典)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1429 胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others)  ...

  6. hdu 1253 胜利大逃亡 (代码详解)解题报告

    胜利大逃亡 Problem Description Ignatius被魔王抓走了,有一天魔王出差去了,这可是Ignatius逃亡的好机会. 魔王住在一个城堡里,城堡是一个A*B*C的立方体,可以被表示 ...

  7. HDU 1253 胜利大逃亡 题解

    胜利大逃亡 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  8. HDU 1429 胜利大逃亡(续)(bfs)

    胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  9. hdu 1253 胜利大逃亡(BFS)

    题目链接:点击链接 三维的BFS,刚开始一直超内存,超无语......  改了n多次终于AC了 #include <iostream> #include <stdio.h> # ...

随机推荐

  1. sql - 修改结构

    1,修改表名 语法: sp_rename old_table_name, new_table_name 例如: sp_rename t_review, t_business 2,修改字段: MySQL ...

  2. DELL磁盘阵列控制卡(RAID卡)MegaCli常用管理命令汇总

    新版本的 MegaCli-1.01.24-0.i386.rpm (下载地址:http://www.lsi.com/downloads/Public/MegaRAID Common Files/8.02 ...

  3. iOS8中添加的extensions总结(二)——分享扩展

    分享扩展 注:此教程来源于http://www.raywenderlich.com的<iOS8 by Tutorials> 1.准备 这次例子来源于国外的图片分享网站Imgur.com 首 ...

  4. PHP 函数的引用传递

    $a = "nowamagic";$b =& $a;echo $b.$a; 这意味着 $a 和 $b 指向了同一个变量.同一个变量内容有不同的变量名,引用就是这么个回事. ...

  5. PHP 类型比较表

    以下的表格显示了 PHP 类型和比较运算符在松散和严格比较时的作用.该补充材料还和类型戏法的相关章节内容有关.同时,大量的用户注释和 » BlueShoes 的工作也给该材料提供了帮助. 在使用这些表 ...

  6. WindowManager

    我们Android平台是一个又一个的Activity组成的,每一个Activity有一个或者多个View构成.所以说,当我们想显示一个界面的时候,我们首先想到的是建立一个Activity,然后所有的操 ...

  7. java虚拟机内存分析

    1.大致来说java虚拟机分为:堆  栈 栈在数据结构就是那个先进后出的栈.堆...这名字我一听就觉得大..毕竟我们形容东西多又没什么大多的组织的时候就是一堆一堆的....(原谅我发散性的思维,我是妹 ...

  8. FileZilla 无法保存密码

    当保存密码时遇到这个问题时: 解决办法: 一.找到FileZilla的设置: 二.点击"界面",取消勾选"不要保存密码",点击"确定"按钮, ...

  9. JSP网页防止sql注入攻击

    SQL注入攻击指的是通过构建特殊的输入作为参数传入Web应用程序,而这些输入大都是SQL语法里的一些组合,通过执行SQL语句进而执行攻击者所要的操作,其主要原因是程序没有细致地过滤用户输入的数据,致使 ...

  10. Nt内核函数原型and中文

    NtLoadDriver 服务控制管理器加载设备驱动. NtUnloadDriver 服务控制管理器支持卸载指定的驱动程序. NtRegisterNewDevice 加载新驱动文件. NtQueryI ...