zju 1671 Walking Ant (bfs 暴搜题)

刚开始还在想怎么去判是否已经走过,但是考虑到它主要是以hp在走,而不是算步数(当然BFS保证步数是最少的),当它在循环跑的时候总会把hp消耗完,还有它可以来回吃实物,但是可以想到,吃食物一次而没有出去的话,这一条路就是不可能通的。那么将食物标记为障碍物即可。

代码如下:

#include<iostream>
#include<cstring>
#include<queue>
using namespace std;

#define MAX_N 11
int t,n,m,map[MAX_N][MAX_N],turn[4][2]={{1,0},{-1,0},{0,-1},{0,1}};
typedef struct{
	int x,y,hp,step;
}point;
point s;

bool init(){

	int i,j;

	memset(map,0,sizeof(map));

	cin>>m>>n;

	if(!(m+n))
		return false;

	for(i=1;i<=n;i++){

		for(j=1;j<=m;j++){

			cin>>map[i][j];

			if(map[i][j]==2)
				s.step=0,s.x=i,s.y=j,s.hp=6;
		}
	}
	return true;
}
int bfs(){
	queue<point > q;
	q.push(s);
	while(!q.empty()){
		point t=q.front(); 
				q.pop();
		t.hp--;

		for(int i=0;i<4;i++){

			point d=t;

			d.x+=turn[i][0];
			d.y+=turn[i][1];
			d.step++;

			if(!map[d.x][d.y] || d.hp <=0 )
				continue;

			map[d.x][d.y]==4?(d.hp=6,map[d.x][d.y]=0):1;

			q.push(d);

			if(map[d.x][d.y] == 3)
				return d.step;
		}
	}
	return -1;
}
int main()
{
	while(init()){

		cout<<bfs()<<endl;
	}
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值