티스토리 뷰

개발/코더 탈출

Dfs와 Bfs의 장단점

-=HaeJuK=- 2024. 2. 2. 16:02
728x90

깊이 우선 탐색 (DFS - Depth-First Search):

  • 설명: DFS는 그래프나 트리에서 깊은 부분을 우선적으로 탐색하는 알고리즘입니다. 한 경로를 끝까지 탐색한 후, 되돌아와서 다음 경로를 탐색하는 방식입니다.
  • 장점:
    1. 간단하고 직관적인 구현이 가능합니다.
    2. 깊은 경로를 먼저 탐색하여 목표에 빠르게 도달할 수 있습니다.
  • 단점:
    1. 최단 경로를 보장하지 않습니다.
    2. 무한 루프에 빠질 수 있으며, 이를 방지하기 위해 방문한 노드를 기록하는 추가적인 공간이 필요합니다.
    3. 특정 상황에서는 최적의 해를 찾지 못할 수 있습니다.

너비 우선 탐색 (BFS - Breadth-First Search):

  • 설명: BFS는 그래프나 트리를 가로지르며 너비를 기준으로 우선적으로 탐색하는 알고리즘입니다. 한 노드에서 인접한 노드를 모두 방문한 후, 그 다음 레벨의 노드로 넘어갑니다.
  • 장점:
    1. 최단 경로를 보장합니다.
    2. 최적의 해를 찾는 데 유용합니다.
    3. 모든 경로를 동등하게 살펴볼 수 있습니다.
  • 단점:
    1. 구현이 복잡하고 메모리를 많이 사용할 수 있습니다.
    2. 깊은 경로를 먼저 탐색하지 않기 때문에 불필요한 경로를 탐색할 수 있습니다.

장단점 비교:

  • DFS 장단점:
    • 장점: 구현이 간단하며 목표에 빠르게 도달할 수 있습니다.
    • 단점: 최단 경로를 보장하지 않고 무한 루프에 빠질 위험이 있습니다.
  • BFS 장단점:
    • 장점: 최단 경로를 보장하고 최적의 해를 찾는 데 유용합니다.
    • 단점: 구현이 복잡하고 메모리를 많이 사용할 수 있습니다.

어떤 알고리즘을 선택할지는 문제의 특성에 따라 다르며, 최단 경로가 중요하거나 모든 경로를 탐색해야 하는 경우에는 BFS를 사용하는 것이 유리할 수 있습니다.

728x90
반응형
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함
반응형