inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-E

개념에 대한 질문입니다.

해결된 질문

113

Codingmaster

작성한 질문수 11

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의 값에서 빼 주는 것인지. 좀 추상적으로 이해가 된 것 같아 여쭤봅니다.

오늘도 감사합니다

c++ 코딩-테스트

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

 

감사합니다.

 

교안 158페이지 문의드립니다

0

23

2

코딩살구클럽 관련 건의사항

0

43

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

22

1

진행 방법 질문드립니다!

0

53

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

59

2

2주차 개념#12 트리 순회

0

27

2

백준사이트가 종료된다고 합니다.

0

287

2

백준 서비스 종료

9

894

1

sk 하이닉스 코테 대비

0

369

2

3-G 최댓값 질문

0

51

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

83

2

3-I 코드 질문드립니다.

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

102

2

4-H 질문 있습니다 (코드 리뷰)

0

66

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

172

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

69

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

64

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

51

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

68

2

함수별 시간복잡도

0

73

2

3-h 질문입니다.

0

49

1

안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.

0

53

2

1-I 문제 질문 드립니다.

0

76

2