1. 학습
  2. /
  3. 강의
  4. /
  5. Python으로 배우는 자료구조와 알고리즘

Connected

연습 문제

그래프에 DFS 구현하기

이 연습 문제에서는 그래프를 순회하기 위한 깊이 우선 탐색(DFS) 알고리즘을 구현해 보겠습니다.

단계를 다시 살펴보면 다음과 같아요:

  1. 임의의 정점에서 시작합니다.
  2. 해당 정점을 방문한 정점 리스트에 추가합니다.
  3. 현재 노드의 인접 정점 각각에 대해
    • 이미 방문했다면 -> 건너뜁니다
    • 아직 방문하지 않았다면 -> DFS를 재귀적으로 수행합니다

코드를 테스트할 수 있도록, 다음 그래프가 딕셔너리를 사용해 로드되어 있어요.

Graphical representation of a graph.

graph = {
  '0' : ['1','2'],
  '1' : ['0', '2', '3'],
  '2' : ['0', '1', '4'],
  '3' : ['1', '4'],
  '4' : ['2', '3']
}

지침

100 XP
  • current_vertex가 아직 방문되지 않았는지 확인하세요.
  • current_vertex를 visited_vertices에 추가하세요.
  • 적절한 값을 전달하여 dfs()를 재귀적으로 호출하세요.