강의

멘토링

커뮤니티

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

dldlsrb9702님의 프로필 이미지
dldlsrb9702

작성한 질문수

it 취업을 위한 알고리즘 문제풀이 입문 (with C/C++) : 코딩테스트 대비

77. 친구인가?(Disjoint-set : Union&Find 알고리즘)

Union&Find vs DFS

작성

·

363

4

안녕하세요 강사님. 
저는 강의를 듣기 전 이번 문제를 인접리스트를 만든 후 DFS를 이용해서 풀었습니다.(66번 경로탐색 처럼)
두 경우 모두 테스트케이스를 통과하였습니다.
혹시 시간이나 메모리 효율성을 고려했을 때 어느 방법을 선택하는 것이 더 좋을지 알 수 있을까요?

답변 2

2

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

사실 이문제는 78번 그루스칼 알고리즘을 설명하기 위해 워밍업 문제로 만든 것 뿐입니다.

이 문제의 경우 친구인지 판별하는 쌍이 하나 뿐이라 DFS로 해도 별 차이가 없지만 대부분 이런 스타일의 문제를 만들때는 친구인지 판별하는 질문이 M개를 물어봅니다. 보통 M은 100이상이 들어옵니다. 그럴때는 유니온앤파인드로 풀어야 합니다.

0

dldlsrb9702님의 프로필 이미지
dldlsrb9702
질문자

넵 답변감사합니다

dldlsrb9702님의 프로필 이미지
dldlsrb9702

작성한 질문수

질문하기