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

미니님의 프로필 이미지
미니

작성한 질문수

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

2주차 개념 #9. 깊이우선탐색(DFS, Depth First Search)

dfs관련 질문

해결된 질문

작성

·

44

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

dfs를 돌릴때 왼쪽부터 탐색하는 이유가 인접리스트를 구성할때 왼쪽의 노드값을 먼저 넣어줬기 때문이라고 추론을 해봤습니다. 그렇다면 인접리스트를 구성할때 순서를 달리하면 (예를 들어 1:: 3,2처럼) dfs가 제대로 작동을 못하지 않습니까? 그럼 인접리스트를 구성할때 어떤 로직에 입각해서 인접 리스트를 작성해야하나요.

답변 1

0

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

안녕하세요 미니님 ㅎㅎ

dfs를 돌릴때 왼쪽부터 탐색하는 이유가 인접리스트를 구성할때 왼쪽의 노드값을 먼저 넣어줬기 때문이라고 추론을 해봤습니다.

>> 네 맞습니다.

코드마다 다르지만 보통은 먼저 넣은 곳부터 탐색을 합니다.

for i in adj[here]

앞의 코드로 할 경우에는 순차적으로 탐색합니다.

 

그렇다면 인접리스트를 구성할때 순서를 달리하면 (예를 들어 1:: 3,2처럼) dfs가 제대로 작동을 못하지 않습니까? 그럼 인접리스트를 구성할때 어떤 로직에 입각해서 인접 리스트를 작성해야하나요.

>> 문제에서 주어진대로 만드시면 됩니다.

만약 문제에서

3, 2로 주어진 것을 3, 2로 만들어라고 하면 -> 3, 2로 만들고

이걸 반대로 만들어라 라고 한다면 -> 2, 3 으로 만드시면 됩니다.

 


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

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

감사합니다.

강사 큰돌 올림.


미니님의 프로필 이미지
미니

작성한 질문수

질문하기