inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-G 와 테스트케이스 팁

3-G 질문 있습니다!

146

김라영

작성한 질문수 22

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.안녕하세요 큰돌님 강의 잘 보고 있습니다! 다름이 아니라 코드 중에 이해가 잘 안되는 부분이 있어서 질문드립니다!if (!visited[next]) { q.push(next); visited[next] = visited[now] + 1; cnt[next] += cnt[now]; } else if (visited[next] == visited[now] + 1) { cnt[next] += cnt[now]; }위와 동일하 코드가 있는데 if(!visited[next])코드는 한번도 방문한 정점이 아니라 처음 방문할 때가 해당 정점을 방문할 최소 시간이라는 것이라는 것은 알겠는데,else if (visited[next] == visited[now] + 1) 이 부분이 어떻게 해당 정점에 방문한 최소 시간이 되는 것을 알 수 있고 그걸 문제를 풀면서 어떻게 도출할 수 있는걸까요?

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 ㅎㅎ

else if (visited[next] == visited[now] + 1) 이 부분이 어떻게 해당 정점에 방문한 최소 시간이 되는 것을 알 수 있고 그걸 문제를 풀면서 어떻게 도출할 수 있는걸까요?

>>

if (!visited[next]) { q.push(next); visited[next] = visited[now] + 1; cnt[next] += cnt[now]; } else if (visited[next] == visited[now] + 1) { cnt[next] += cnt[now]; }

이 코드를 해석해볼게요.

BFS로 visited를 만든다 => visited에는 최단거리가 쌓임.

visited[next] = visited[now] + 1;이라는 식을 기반으로 최단거리가 쌓임.

 

 

else if (visited[next] == visited[now] + 1) { cnt[next] += cnt[now]; }

>> 만약 이 정점으로부터 그 다음의 정점이 최단거리다?(visited[next] == visited[now] + 1)-> 최단거리의 경우의수를 더한다.

라고 보시면 됩니다.



또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


 

 

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 김라영님의 질문과 관련하여, 3-G번 질문있습니다. 게시글이 비슷한 상황에서의 질문과 답변을 제공하고 있습니다.

질문자가 언급한 코드는 BFS(Breadth-First Search, 너비 우선 탐색)를 이용하여 최단 경로를 찾는 과정에서 사용하는 로직입니다. if (!visited[next]) 부분은 해당 정점을 처음 방문할 때 행하는 조건 처리이며, else if (visited[next] == visited[now] + 1) 조건은 이미 방문한 정점에 대해 현재 경로가 최단 경로와 동일한 경우, 즉 최단 거리를 가지는 다른 경로가 존재하는 경우를 처리합니다. 이렇게 하면 해당 정점까지 도달하는 데에 걸리는 최소 시간과 그 시간에 도달하는 서로 다른 경로의 수를 계산할 수 있습니다.

기존 답변에서는 이 조건문이 왜 최단 거리를 보장하는지, 왜 이러한 조건을 체크하는지에 대해 설명하고 있습니다. 동시에 최단 경로로 도달할 수 있는 다양한 방법의 수를 계산하는 데 있어서 중요한 역할을 한다고 설명하고 있습니다.

따라서 visited[next] == visited[now] + 1 조건은, 현재 정점에서 다음 정점까지 이동한 거리가 이미 저장된 다음 정점까지의 거리(최소 거리)와 같을 경우를 나타냅니다. 이는 추가적인 경로가 있음을 의미하며, 이를 통해 최소 거리를 유지하면서도 경로의 수를 계산할 수 있습니다.

해당 질문과 관련하여 더 깊이 있는 설명이 필요한 경우, 제안된 링크에서 제공되는 답변 및 추가적인 설명을 살펴보시기를 권장드립니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

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

0

10

2

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

0

29

1

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

0

13

1

진행 방법 질문드립니다!

0

45

2

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

0

55

2

2주차 개념#12 트리 순회

0

26

2

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

0

286

2

백준 서비스 종료

9

890

1

sk 하이닉스 코테 대비

0

367

2

3-G 최댓값 질문

0

50

1

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

0

83

2

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

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

102

2

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

0

66

2

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

0

170

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