用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){
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)。