HDU 1253 승리 대 탈출 (3 차원 배열 + bfs)
1357 단어 bfs
제목 의 뜻 은 더 이상 말 하지 않 겠 다 미궁 류 문제 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
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
나무깊이 우선 탐색(DFS) 깊이 우선 검색(DFS)은 트리 또는 그래프 데이터 구조를 탐색하거나 검색하기 위한 알고리즘입니다. 하나는 루트에서 시작하여(그래프의 경우 임의의 노드를 루트로 선택) 역추적하기 전에 각 분...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.