inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-E

개념에 대한 질문입니다.

해결된 질문

117

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

 

감사합니다.

 

코딩살구클럽 문의

0

7

1

코딩살구클럽 승인

0

18

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

27

2

3-F 채점 관련 질문

0

24

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

28

2

코딩살구클럽 승인

0

41

2

코딩살구클럽승인

0

33

3

코딩살구클럽 승인

0

48

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

43

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

53

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

61

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

64

2

코딩살구클럽 로그인문제

0

78

3

코딩 살구 클럽 로그인 문제

0

82

2

2-J 채점관련 질문

0

65

3

코딩 살구 클럽 Python 지원 가능 여부

0

77

1

살구클럽 아이디 없음 문제

0

76

1

1-O 코딩살구클럽 채점관련 질문

0

60

2

히든 테스트 케이스가 사라졌습니다

0

57

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

74

2