inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2주차 개념 #10. 너비우선탐색(BFS, Breadth First Search)

visited와 거리의 관련

해결된 질문

81

양재욱

작성한 질문수 7

0

안녕하세요 큰돌님 열심히 수강중인 학생입니다.

이번 강의를 들으면서 조금 이해가 안가는 부분이 생겼습니다.

visited는 방문 여부를 나타내기위한 배열인것으로 알고있는데 거리관련 배열을 새로 선언한것보다

visited에 거리를 추가해주는것이 더 편리한거같긴한데 나중에 문제를 풀때도 그냥 통합해서

풀어도 문제가 없을까요? 한가지 배열로 두가지 역할을 하다보니

나중에 문제 풀이 중에 문제가 생기지 않을까 걱정되는 마음에 질문 드립니다!

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 재욱님ㅎㅎ

문제에서 주어지는 맵에 대한 배열을 따로 생성하지 않고 그걸 visited에 다 넣는다는 말씀이신가요?

 

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 양재욱님.

알고리즘 문제에서 visited 배열은 주로 노드의 방문 여부를 확인하기 위해 사용됩니다. 하지만 특정 문제에서는 visited 배열에 거리를 함께 저장하는 방식이 더 간결하고 효과적일 수 있습니다. 이는 특히 BFS(너비 우선 탐색)와 같은 알고리즘에서 흔히 사용되는 기법입니다.

이렇게 배열을 통합하여 사용하더라도, 문제를 명확하게 이해하고 신중히 설계한다면 문제가 되지 않습니다. 다만, 문제의 요구사항이나 복잡도에 따라 주의하실 점은 다음과 같습니다:

  1. 명료성 유지: 배열의 용도가 명확하지 않으면 혼동을 초래할 수 있습니다. 따라서 코드를 읽는 사람들이 배열의 활용 방식을 쉽게 이해할 수 있도록 주석을 잘 작성하는 것이 중요합니다.

  2. 문제의 특성 확인: 모든 문제에 이 방식이 적용되는 것은 아니므로, 문제의 성격에 따라 적절한 방식을 선택하는 것이 중요합니다.

  3. 에러 핸들링: 두 가지 역할을 하나의 배열에서 다루게 되면 오버플로우나 데이터 표현 범위와 관련한 에러가 발생할 수 있으니 주의가 필요합니다.

관련된 질문과 답변을 통해 더 다양한 접근법을 이해하실 수 있도록 8-U 질문있습니다 :) 게시물도 참고해 보세요.

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

문제를 고민하는 시간 관련

0

9

2

코딩살구클럽

0

13

1

코딩살구클럽 문의

0

26

2

코딩살구클럽 승인

0

30

2

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

0

32

2

3-F 채점 관련 질문

0

29

1

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

0

32

2

코딩살구클럽 승인

0

41

2

코딩살구클럽승인

0

38

3

코딩살구클럽 승인

0

50

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

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

0

63

2

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

0

64

2

코딩살구클럽 로그인문제

0

78

3

코딩 살구 클럽 로그인 문제

0

84

2

2-J 채점관련 질문

0

66

3

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

0

77

1

살구클럽 아이디 없음 문제

0

76

1

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

0

60

2