해결된 질문
작성
·
43
0
#include "bits/stdc++.h"
using namespace std;
constexpr int V = 3;
int DamageSequence[6][3] = { { 9, 3, 1 }, { 9, 1, 3 }, { 3, 9, 1 }, { 3, 1, 9 }, { 1, 9, 3 }, { 1, 3, 9 } };
int visited[64][64][64], scv[3], n;
queue<tuple<int, int, int>> q;
int BFS(int param1, int param2, int _param3)
{
visited[_param1][_param2][_param3] = 1;
q.push({ param1, param2, _param3 });
while (!q.empty())
{
int first = get<0>(q.front());
int second = get<1>(q.front());
int third = get<2>(q.front());
q.pop();
if (visited[0][0][0])
break;
for (int i = 0; i < 6; i++)
{
int nextFirst = max(0, first - DamageSequence[i][0]);
int nextSecond = max(0, second - DamageSequence[i][1]);
int nextThird = max(0, third - DamageSequence[i][2]);
if (visited[nextFirst][nextSecond][nextThird])
continue;
visited[nextFirst][nextSecond][nextThird] = visited[first][second][third] + 1;
q.push({ nextFirst, nextSecond, nextThird });
}
}
return visited[0][0][0] - 1;
}
int main()
{
ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
cin >> n;
for (int i = 0; i < n; i++)
cin >> scv[i];
cout << BFS(scv[0], scv[1], scv[2]) << "\n";
return 0;
}
1번째 질문은 일단 이해가 좀 가질 않는 부분은 BFS()를 호출해줄 때
각 SCV의 체력을 인덱스로 하는 지점에서 시작하는부분이 좀 이해가 가질 않습니다.
체력을 기준으로 0, 0, 0에서 시작한다고 생각을 했는데 왜 배열의 중간부분부터 탐색을 해나가는지 궁금합니다.
2번 째 질문입니다.
만약 그게 좌표의 개념이라면 모두가 0이 되는 점 까지의 거리라서 BFS를 진행한 후에 visited의 0,0,0의 값에서 빼 주는 것인지. 좀 추상적으로 이해가 된 것 같아 여쭤봅니다.
오늘도 감사합니다
답변 1
0
안녕하세요 봄님 ㅎㅎ
저번에 다른 분댓글 달아주신것도 잘 봤습니다. 정말 감사드립니다. ㅎㅎ
체력을 기준으로 0, 0, 0에서 시작한다고 생각을 했는데 왜 배열의 중간부분부터 탐색을 해나가는지 궁금합니다.
>>
cout << BFS(scv[0], scv[1], scv[2]) << "\n";
이부분이죠? ㅎ 체력이 감소되기 때문에 체력이 있는 상태에서 -> 0, 0,0으로 들어가는 것입니다.
만약 그게 좌표의 개념이라면 모두가 0이 되는 점 까지의 거리라서 BFS를 진행한 후에 visited의 0,0,0의 값에서 빼 주는 것인지. 좀 추상적으로 이해가 된 것 같아 여쭤봅니다.
>> 네 맞습니다. 그니까 이렇게 생각하시면 됩니다. 체력이 50인 사람이 -> 0이 될 때까지의 시간을 구해라 라고 한다면 50부터 시작해서 -> 계속 여러 조건에 의해 빼다가 -> 0이 됬을 때의 시간을 구하면 되겠죠?
감사합니다.