AOJ problem 6 Hero In Maze
来源:互联网 发布:兰溪行知学院招租店面 编辑:程序博客网 时间:2024/04/29 12:48
Hero In Maze
Time Limit: 1000 ms Case Time Limit: 1000 ms Memory Limit: 64 MB
Total Submission: 1267 Submission Accepted: 199
Total Submission: 1267 Submission Accepted: 199
Description
500年前,Jesse是我国最卓越的剑客。他英俊潇洒,而且机智过人^_^。
突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中。Jesse听说这个消息已经是两天以后了,他知道公主在迷宫中还能坚持T天,他急忙赶到迷宫,开始到处寻找公主的下落。
时间一点一点的过去,Jesse还是无法找到公主。最后当他找到公主的时候,美丽的公主已经死了。从此Jesse郁郁寡欢,茶饭不思,一年后追随公主而去了。T_T
500年后的今天,Jesse托梦给你,希望你帮他判断一下当年他是否有机会在给定的时间内找到公主。
他会为你提供迷宫的地图以及所剩的时间T。请你判断他是否能救出心爱的公主。
突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中。Jesse听说这个消息已经是两天以后了,他知道公主在迷宫中还能坚持T天,他急忙赶到迷宫,开始到处寻找公主的下落。
时间一点一点的过去,Jesse还是无法找到公主。最后当他找到公主的时候,美丽的公主已经死了。从此Jesse郁郁寡欢,茶饭不思,一年后追随公主而去了。T_T
500年后的今天,Jesse托梦给你,希望你帮他判断一下当年他是否有机会在给定的时间内找到公主。
他会为你提供迷宫的地图以及所剩的时间T。请你判断他是否能救出心爱的公主。
Input
题目包括多组测试数据。
每组测试数据以三个整数N,M,T(0 < N,M <= 20)开头,
分别代表迷宫的长和高,以及公主能坚持的天数。
紧接着有M行,N列字符,由".","*","P","S"组成。其中
"." 代表能够行走的空地。
"*" 代表墙壁,Jesse不能从此通过。
"P" 是公主所在的位置。
"S" 是Jesse的起始位置。
每个时间段里Jesse只能选择“上、下、左、右”任意一方向走一步。
输入以0 0 0结束。
每组测试数据以三个整数N,M,T(0 < N,M <= 20)开头,
分别代表迷宫的长和高,以及公主能坚持的天数。
紧接着有M行,N列字符,由".","*","P","S"组成。其中
"." 代表能够行走的空地。
"*" 代表墙壁,Jesse不能从此通过。
"P" 是公主所在的位置。
"S" 是Jesse的起始位置。
每个时间段里Jesse只能选择“上、下、左、右”任意一方向走一步。
输入以0 0 0结束。
Output
如果能在规定时间内救出公主输出“YES”,否则输出“NO”。
Sample Input
OriginalTransformed4 4 10............S**P0 0 0
4[SP]4[SP]10[EOL] ....[EOL] ....[EOL] ....[EOL] S**P[EOL] 0[SP]0[SP]0[EOF]
Sample Output
OriginalTransformedYES
YES[EOF]
Source
陆泽西
----------------------------------------------------分割线------------------------------------------------------
思路:楼主做这题时开始各种tl,又是各种wa,后来终于ac了,开个结构体用来存储节点,从起点开始出发用bfs遍历整个图
满足条件就进入队列,访问一个节点之后同时访问节点边的4个节点,下面贴代码
#include<iostream>#include<cstring>using namespace std;int n,m,t;int dir[4][2]={{-1,0},{0,-1},{1,0},{0,1}}; //方向 char map[25][25]; //用map存储地图 int ans[25][25];//记录走的步数 typedef struct{int x;int y;}node;int bfs(node s,node e){node que[1000];node t,tt;map[s.x][s.y]='*';int head=0,tail=0;que[tail++]=s;while(head<tail){t=que[head++];for(int i=0;i<4;i++){tt.x=t.x+dir[i][0];tt.y=t.y+dir[i][1];if(tt.x>=0&&tt.x<n&&tt.y>=0&&tt.y<n&&map[tt.x][tt.y]!='*') //判断当前步可以走的话 {que[tail++]=tt;//入队 map[tt.x][tt.y]='*';//标记当前地图已经走过 ans[tt.x][tt.y]=ans[t.x][t.y]+1;//记录步数 if(tt.x==e.x&&tt.y==e.y){return ans[tt.x][tt.y];}}}}return 0;}int main(){node s,e;int i,j;while(cin>>n>>m>>t){if(n==0&&m==0&&t==0) break;memset(map,0,sizeof(map));memset(ans,0,sizeof(ans));for(i=0;i<m;i++){for(j=0;j<n;j++){cin>>map[i][j];if(map[i][j]=='S'){s.x=i;s.y=j;}else if(map[i][j]=='P'){e.x=i;e.y=j;}}}int temp=bfs(s,e);if(temp>0&&temp<=t) cout<<"YES"<<endl;else cout<<"NO"<<endl;}return 0;}
0 0
- AOJ problem 6 Hero In Maze
- aoj 6 Hero In Maze
- AOJ-AHU-OJ-6 Hero in Maze
- AOJ 6 Hero In Maze 【BFS】
- AOJ-AHU-OJ-6 Hero in maze(拓展)
- Hero In Maze
- hero in maze
- hero in maze 迷宫
- AOJ6 Hero In Maze
- Hero In Maze
- Hero In Maze
- Hero In Maze(bfs)
- 6.Hero In Maze
- Hero In Maze
- Hero In Maze
- Hero In Maze 简单版
- 3305: Hero In Maze II
- YTU 1006 Hero In Maze
- select 语句生成序号
- hdu 1001 sum problem
- 为什么乐蜂网的估值这么低
- js实现网页标题不断改变效果
- C++0x FAQ中文版:std::function 和 std::bind - [C++11 FAQ]
- AOJ problem 6 Hero In Maze
- dgjhk
- zoj 2966
- SqlServer表和EXCEL数据批量复制方法(已解决)
- PMP-项目管理笔记(四)-项目范围管理-收集需求
- 三国杀---用于练习继承和多态
- SSO说明
- (code jam)Problem A. Minimum Scalar Product
- hhjj,