AOJ problem 6 Hero In Maze

Hero In Maze
Time Limit: 1000 ms   Case Time Limit: 1000 ms   Memory Limit: 64 MB
Total Submission: 1267   Submission Accepted: 199
Description
500年前,Jesse是我国最卓越的剑客。他英俊潇洒,而且机智过人^_^。

突然有一天,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结束。

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

Sample Input
OriginalTransformed
4 4 10
....
....
....
S**P
0 0 0
4[SP]4[SP]10[EOL] 
....[EOL] 
....[EOL] 
....[EOL] 
S**P[EOL] 
0[SP]0[SP]0[EOF] 

Sample Output
OriginalTransformed
YES
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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值