hdu--Walking Ant

许多纯bfs的题目,通常都可以用模板进行套用,只是有时候,还需要考虑题目所给的条件,只要在模板中加上约束条件就行了。

代码如下:

#include<stdio.h>
#include<queue>
using namespace std;
int t[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
using namespace std;
int w,h,sx,sy,ex,ey;
int ans;
int vin[10][10];
struct stu
{
	int x;
	int y;
	int hp;
	int t;
}temp,a;
int check(struct stu b)
{
	if(b.x<1||b.x>h||b.y<1||b.y>w||vin[b.x][b.y]==0||b.hp<=0)
	return 0;
	else return 1;
}
void bfs()
{
	int i,k;
	k=0;
	a.x=sx;
	a.y=sy;
	a.hp=6;
	a.t=0;
    queue<stu>q;
	q.push(a);
	while(!q.empty())
	{
		a=q.front();
		q.pop();
		for(i=0;i<4;i++)
		{
			temp.x=a.x+t[i][0];
			temp.y=a.y+t[i][1];
			temp.t=a.t+1;
		    temp.hp=a.hp-1;
			if(check(temp))
			{
			  if(vin[temp.x][temp.y]==4)
			    {
			    temp.hp=6;vin[temp.x][temp.y]=0;
				}//最终都不能到家的蚂蚁回因为Hp的消耗而死,栈就会空 
				//同样步数到达食物处的选其中一种走法就行 
			  if(temp.x==ex&&temp.y==ey)
			  {
			  	ans=temp.t;
			  	return;
			  }  
			     /*if(vin[temp.x][temp.y]==1||vin[temp.x][temp.y]==2)
			     {
			     	vin[temp.x][temp.y]==0;
			     }*///一开始设这个条件的话,会出现蚂蚁在两个相邻的食物之间来回走
				 //而且因为Hp的限制,蚂蚁需要回走,获得能量后继续向前,即是Hp在走;
				 //例如8,5,13的案例 
			     q.push(temp);
			}
		}
	}		
}
int main()
{
         int i,j;
	while(scanf("%d%d",&w,&h),w|h)
	{
		for(i=1;i<=h;i++)
		for(j=1;j<=w;j++)
		{
			scanf("%d",&vin[i][j]);
			if(vin[i][j]==2)
			{
				sx=i;sy=j;
			}
			if(vin[i][j]==3)
			{
				ex=i;
				ey=j;
			}
			
		}
		ans=0;
		bfs();
		if(ans==0)
		printf("-1\n");
		else printf("%d\n",ans);
	}
	return 0;
}


 

 

 

你可能感兴趣的:(hdu--Walking Ant)