AOJ 1005 Hero In Maze BFS

Hero In Maze

Time Limit:JAVA/Others2000/1000MS  Memory Limit:JAVA/Others131072/65536KB
Total Submit:240 Accepted:51

Description

500年前,Jesse是我国最卓越的剑客。他英俊潇洒,而且机智过人^_^。

突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中。Jesse听说这个消息已经是两天以后了,他知道公主在迷宫中还能坚持T天,他急忙赶到迷宫,开始到处寻找公主的下落。
时间一点一点的过去,Jesse还是无法找到公主。最后当他找到公主的时候,美丽的公主已经死了。从此Jesse郁郁寡欢,茶饭不思,一年后追随公主而去了。T_T
500年后的今天,Jesse托梦给你,希望你帮他判断一下当年他是否有机会在给定的时间内找到公主。

他会为你提供迷宫的地图以及所剩的时间T。请你判断他是否能救出心爱的公主。

Input

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

Output

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

Sample Input

4 4 10
....
....
....
S**P
0 0 0

Sample Output

YES

写的第一个BFS,激动!!
代码如下,高手飘过,你们根本不需要看,太初级了。
这个代码主要两个地方花了很多时间:
1,队列本应从队头取元素的,我从尾部取了,后来用queue的front和push可以很方便的实现。
2.,是没有考虑公主被包围的情况,即公主周围全是‘*’,那么王子就没办法达到,这样dist[x2][y2](x2,y2是公主的位置)一直是0,肯定小于t;
 1#include<iostream>
 2#include<queue>
 3using namespace std;
 4char a[105][105];
 5bool f[105][105];
 6int dist[105][105];
 7struct point 
 8int x,y; };
 9
10bool valid(int x,int y)
11return !f[x][y]&&a[x][y]!='*'&&a[x][y]; }
12
13void bfs(int i,int j)
14{
15     dist[i][j]=0; f[i][j]=1;
16     struct point tem;
17     tem.x=i; tem.y=j;
18     queue<struct point>q;
19     q.push(tem);
20      while(q.size())
21      {
22         tem=q.front();q.pop(); 
23         int x=tem.x,y=tem.y;
24         if(valid(x-1,y)){f[x-1][y]=1;  dist[x-1][y]=dist[x][y]+1;tem.x=x-1; tem.y=y; q.push(tem);}
25         if(valid(x,y-1)){f[x][y-1]=1;  dist[x][y-1]=dist[x][y]+1;tem.x=x; tem.y=y-1; q.push(tem);}
26         if(valid(x+1,y)){f[x+1][y]=1;  dist[x+1][y]=dist[x][y]+1;tem.x=x+1; tem.y=y; q.push(tem);}
27         if(valid(x,y+1)){f[x][y+1]=1;  dist[x][y+1]=dist[x][y]+1;tem.x=x; tem.y=y+1; q.push(tem);}
28      }

29    
30}

31
32int main()
33{
34    int n,m,t,i,j,u;
35    int x,y,x2,y2;
36    while(cin>>m>>n>>t,n||m||t)
37    {
38      memset(a,0,sizeof a);
39      memset(f,0,sizeof f);
40      memset(dist,0,sizeof dist);
41      x=y=x2=y2=1;
42      for(i=1; i<=n; i++)
43      for(j=1; j<=m;j++)
44       {
45                cin>>a[i][j];
46                if(a[i][j]=='S'){x=i; y=j;}
47                else if(a[i][j]=='P'){x2=i; y2=j; }
48       }

49    
50       bfs(x,y);
51   
52      if(x==x2&&y==y2)cout<<"YES"<<endl;
53      else if(dist[x2][y2]==0)cout<<"NO"<<endl;
54      else if(dist[x2][y2]<=t)cout<<"YES"<<endl;
55      else cout<<"NO"<<endl;
56    }

57 
58   return 0;   
59}

posted on 2010-05-20 21:58 田兵 阅读(1423) 评论(2)  编辑 收藏 引用 所属分类: 算法笔记

评论

# re: AOJ 1005 Hero In Maze BFS[未登录] 2010-05-21 22:54 meta

AOJ是哪里的Online Judge啊,没有找到啊~  回复  更多评论   

# re: AOJ 1005 Hero In Maze BFS 2010-05-22 18:11 田兵

http://icpc.ahu.edu.cn:81/AOJ/
学校的OJ,不出名,都是给自己做的,  回复  更多评论   


只有注册用户登录后才能发表评论。
【推荐】超50万行VC++源码: 大型组态工控、电力仿真CAD与GIS源码库
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2020年7月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

导航

统计

常用链接

留言簿(2)

随笔分类(65)

随笔档案(65)

文章档案(2)

ACM

搜索

积分与排名

最新随笔

最新评论

阅读排行榜