44分(全输出-1)BFS
  • 板块P2802 回家
  • 楼主kungeruyi
  • 当前回复2
  • 已保存回复2
  • 发布时间2024/12/15 11:06
  • 上次更新2024/12/15 14:30:29
查看原帖
44分(全输出-1)BFS
1101352
kungeruyi楼主2024/12/15 11:06

用BFS做44分,Wrong answer 。

代码如下:

#include<bits/stdc++.h>
using namespace std;
const int N=50;
int a[N][N],f[N][N];
int HP=6;
struct node{
	int x,y,HP,step;
}q[N*N];
int n,m;
int sx,sy,fx,fy;
int dx[4]={0,-1,0,1};
int dy[4]={1,0,-1,0};
int head,tail;
int bfs(){
	head=0,tail=1;
	q[tail].x=sx;
	q[tail].y=sy;
	q[tail].HP=6;
	q[tail].step=0;
	while(head<tail){
		head++;
		int x,y,step,hp;
		x=q[head].x;
		y=q[head].y;
		step=q[head].step;
		hp=q[head].HP;
		if(hp<=0)
			continue;
		if(x==fx && y==fy){
			return step;
		}
		if(a[x][y]==4){
			hp=6;
		}
		for(int i=0;i<=3;i++){
			int nx=x+dx[i];
			int ny=y+dy[i];
			if(!f[nx][ny] && nx>0 && ny>0 && nx<=n && ny<=m){
//				f[nx][ny]=1;
				if((hp-1)!=0){
					tail++;
					q[tail].x=nx;
					q[tail].y=ny;
					q[tail].step=step+1;
					q[tail].HP=hp-1;
				}
			}
		}
	}
	return -1;
}
int main()
{
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cin>>a[i][j];
			if(!a[i][j]){
				f[i][j]=1;
			}
			else if(a[i][j]==2){
				sx=i;
				sy=j;
			}
			else if(a[i][j]==3){
				fx=i;
				fx=j;
			}
		}
	}
	cout<<bfs();
	return 0;
}

测试点信息

样例没过(不管什么数据,都输出-1)。

2024/12/15 11:06
加载中...