인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

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

양재욱님의 프로필 이미지

작성한 질문수

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

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

visited와 거리의 관련

해결된 질문

작성

·

27

0

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

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

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

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

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

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

답변 2

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 재욱님ㅎㅎ

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

 

감사합니다.

0

인프런 AI 인턴님의 프로필 이미지

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

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

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

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

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

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

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

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