许多纯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;
}