인프런 커뮤니티 질문&답변

__yourspring님의 프로필 이미지
__yourspring

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

3-E

개념에 대한 질문입니다.

해결된 질문

작성

·

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이 됬을 때의 시간을 구하면 되겠죠?

 

감사합니다.

 

__yourspring님의 프로필 이미지
__yourspring

작성한 질문수

질문하기