HDU 1072/BFS
来源:互联网 发布:matlab定义空矩阵 编辑:程序博客网 时间:2024/06/06 03:19
题目链接
Nightmare
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 10069 Accepted Submission(s): 4910
Problem Description
Ignatius had a nightmare last night. He found himself in a labyrinth with a time bomb on him. The labyrinth has an exit, Ignatius should get out of the labyrinth before the bomb explodes. The initial exploding time of the bomb is set to 6 minutes. To prevent the bomb from exploding by shake, Ignatius had to move slowly, that is to move from one area to the nearest area(that is, if Ignatius stands on (x,y) now, he could only on (x+1,y), (x-1,y), (x,y+1), or (x,y-1) in the next minute) takes him 1 minute. Some area in the labyrinth contains a Bomb-Reset-Equipment. They could reset the exploding time to 6 minutes.
Given the layout of the labyrinth and Ignatius’ start position, please tell Ignatius whether he could get out of the labyrinth, if he could, output the minimum time that he has to use to find the exit of the labyrinth, else output -1.
Here are some rules:
1. We can assume the labyrinth is a 2 array.
2. Each minute, Ignatius could only get to one of the nearest area, and he should not walk out of the border, of course he could not walk on a wall, too.
3. If Ignatius get to the exit when the exploding time turns to 0, he can’t get out of the labyrinth.
4. If Ignatius get to the area which contains Bomb-Rest-Equipment when the exploding time turns to 0, he can’t use the equipment to reset the bomb.
5. A Bomb-Reset-Equipment can be used as many times as you wish, if it is needed, Ignatius can get to any areas in the labyrinth as many times as you wish.
6. The time to reset the exploding time can be ignore, in other words, if Ignatius get to an area which contain Bomb-Rest-Equipment, and the exploding time is larger than 0, the exploding time would be reset to 6.
Input
The input contains several test cases. The first line of the input is a single integer T which is the number of test cases. T test cases follow.
Each test case starts with two integers N and M(1<=N,Mm=8) which indicate the size of the labyrinth. Then N lines follow, each line contains M integers. The array indicates the layout of the labyrinth.
There are five integers which indicate the different type of area in the labyrinth:
0: The area is a wall, Ignatius should not walk on it.
1: The area contains nothing, Ignatius can walk on it.
2: Ignatius’ start position, Ignatius starts his escape from this position.
3: The exit of the labyrinth, Ignatius’ target position.
4: The area contains a Bomb-Reset-Equipment, Ignatius can delay the exploding time by walking to these areas.
Output
For each test case, if Ignatius can get out of the labyrinth, you should output the minimum time he needs, else you should just output -1.
Sample Input
3
3 3
2 1 1
1 1 0
1 1 3
4 8
2 1 1 0 1 1 1 0
1 0 4 1 1 0 4 1
1 0 0 0 0 0 0 1
1 1 1 4 1 1 1 3
5 8
1 2 1 1 1 1 1 4
1 0 0 0 1 0 0 1
1 4 1 0 1 1 0 1
1 0 0 0 0 3 0 1
1 1 4 1 1 1 1 1
Sample Output
4
-1
13
Author
Ignatius.L
/*题意很好懂,这道题的关键点在于判断哪些点可以重复走而能走出去并达到最优解。某个点已经走过但是再一次到达这个点的时候剩余的时间大于第一次到达这个点的时候所剩余的时间,这加入队列。时间为1的点为无效点,不能加入队列。*/#include<queue>#include<cstdio>#include<cstring>#include<iostream>#include<algorithm>using namespace std;const int maxn=15;const int inf=1e9;int maze[maxn][maxn];int Ti[maxn][maxn];int dir[4][2]={1,0,0,1,-1,0,0,-1};int n,m;int xt,yt;struct node{ int x; int y; int time; int step;};int BFS(){ queue<node>que; node now,next; now.x=xt; now.y=yt; now.time=6; now.step=0; que.push(now); while(!que.empty()) { now=que.front(); que.pop(); for(int i=0;i<4;i++) { int x=now.x+dir[i][1]; int y=now.y+dir[i][0]; if(x>=1&&x<=n&&y>=1&&y<=m&&maze[x][y]>0) { if(maze[x][y]==4) { next.x=x; next.y=y; next.time=6; next.step=now.step+1; que.push(next); maze[x][y]=0;// } else if(maze[x][y]==3) { if(now.time>1) return now.step+1; } else if(now.time-1>Ti[x][y]&&now.time-1>1) { next.x=x; next.y=y; next.time=now.time-1; next.step=now.step+1; Ti[x][y]=next.time; que.push(next); } } } } return -1;}int main (){ int T;scanf("%d",&T); while(T--) { memset(Ti,0,sizeof(Ti)); scanf("%d%d",&n,&m); for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) { scanf("%d",&maze[i][j]); if(maze[i][j]==2) xt=i,yt=j; } int t=BFS(); printf("%d\n",t); } return 0;}
- HDU 1072(BFS)
- BFS hdu 1072 Nightmare
- HDU 1072 Nightmare BFS
- hdu 1072 Nightmare BFS
- HDU 1072 BFS
- hdu 1072 Nightmare bfs
- hdu 1072 BFS
- HDU 1072 BFS
- Hdu 1072 Nightmare[Bfs]
- HDU 1072(bfs)
- hdu 1072 Nightmare--bfs
- hdu 1072bfs
- HDU 1072 Nightmare(BFS)
- HDU 1072 Nightmare (BFS)
- HDU 1072 Nightmare (BFS)
- bfs-hdu-1072-Nightmare
- HDU 1072 Nightmare【BFS】
- HDU 1072 Nightmare BFS
- 数据结构实验之排序三:bucket sort
- CodeForce 706C 动态规划 利用下标表示状态 递推 (伪状态压缩)
- 【poj1274】 The Perfect Stall
- Thinkphp 微博项目
- 网络广告CPC、CPM和CTR的定义和关系
- HDU 1072/BFS
- eclipse maven安装配置
- POJ 2019 Cornfields (二维RMQ)
- 使用loadrunner编写dubbo接口的性能测试脚本
- codeforces 706D. Vasiliy's Multiset 带删除操作的字典树(真模版)
- 黄阶低级 - 《 Java 核心》- 3.7 输入输出 - 修改0次
- 数据库之SQL
- Codeforces #367(Div.2)C.Hard problem【dp】
- 怎样设置VMware虚拟机(Ubuntu)和主机Window文件共享