HDU 1253 승리 대 탈출 (3 차원 배열 + bfs)

1357 단어 bfs
http://acm.hdu.edu.cn/showproblem.PHP?pid=1253
제목 의 뜻 은 더 이상 말 하지 않 겠 다 미궁 류 문제  bfs 로 하면 돼 요. 
AC 코드:
#include   
#include   
#include   
using namespace std;  
   
int A,B,C,T;  
int map[55][55][55];  
int vis[55][55][55];  
int dirx[]={0,0,0,0,1,-1};  
int diry[]={0,0,1,-1,0,0};  
int dirz[]={1,-1,0,0,0,0};  
int flag;  
  
struct node{  
    int x;  
    int y;  
    int z;  
    int step;   
};   
  
  
int judge(int x,int y,int z){  
    if (x>=0&&x=0&&y=0&&zQ;  
node a;  
a.x=0;  
a.y=0;  
a.z=0;  
a.step=0;  
vis[0][0][0]=1;  
Q.push(a);  
flag=1;   
while (!Q.empty()){  
a=Q.front();  
Q.pop();  
if (a. step > T) / / 처음에 이 판단 을 넣 지 않 았 는데 시간 이 여러 번 초과 되 었 습 니 다.
{  
break;  
}  
if (a.x==A-1&&a.y==B-1&&a.z==C-1&&a.step<=T){  
printf ("%d",a.step);  
flag=0;  
break;  
}  
for (int i=0;i<6;i++){  
node b;  
b=a;  
b.x+=dirx[i];  
b.y+=diry[i];  
b.z+=dirz[i];  
if (judge(b.x,b.y,b.z)){  
b.step++;  
vis[b.x][b.y][b.z]=1;  
Q.push(b);  
}  
}   
}  
if (flag){  
printf ("-1");  
}  
}  
int main (){  
int n;  
scanf ("%d",&n);  
while (n--){  
scanf ("%d%d%d%d",&A,&B,&C,&T);  
for (int i=0;i

좋은 웹페이지 즐겨찾기