1. DFS(Depth-First Search)의 개념
- DFS는 깊이 우선 탐색이라고도 부르며 그래프에서 깊은 부분을 우선적으로 탐색하는 알고리즘
- DFS는 스택 자료구조(혹은 재귀 함수)를 이용하며, 구체적인 동작 과정은 다음과 같음
- 탐색 시작 노드를 스택에 삽입하고 방문 처리함
- 스택의 최상단 노드에 방문하지 않은 인접한 노드가 하나라도 있으면 그 노드를 스택에 넣고 방문 처리함. 방문하지 않은 인접 노드가 없으면 스택에서 최상단 노드를 꺼냄.
- 더 이상 2번의 과정을 수행할 수 없을 때까지 반복.
2. DFS 동작 예시
- [Step 1] 그래프를 준비 (시작노드 : 1)
- [Step 2] 시작 노드인 '1'을 스택에 삽입하고 방문 처리
- [Step 3] 스택의 최상단 노드인 '1'에 방문하지 않은 인접 노드 '2','3','8' 중 가장 작은 노드인 '2'를 스택에 넣고 방문 처리를 함.
- [Step 4] 스택의 최상단 노드인 '2'에 방문하지 않은 인접 노드'7'이 있음. 따라서 '7'번 노드를 스택에 넣고 방문 처리
- [Step 5] 스택의 최상단 노드인 '7'에 방문하지 않은 인접 노드 '6','8' 중 가장 작은 노드인 '6'을 스택에 넣고 방문 처리
- [Step 6] 스택의 최상단 노드인 '6'에 방문하지 않은 인접 노드가 없기 떄문에 스택에서 '6'번 노드를 꺼냄.
- [Step 7] 스택의 최상단 노드인 '7'에 방문하지 않은 인접 노드가 '8'이 있음. 따라서 '8'번 노드를 스택에 넣고 방문처리
- 이 과정 반복
- 이러한 과정을 반복하였을 때 전체 노드의 탐색 순서(스택에 들어간 순서)는 다음과 같음
- 탐색 순서 : 1 -> 2 -> 7 -> 6 -> 8 -> 3 -> 4 -> 5
3. DFS 코드 구현
4. BFS(Breadth-First Search)의 개념
- BFS는 너비 우선 탐색이라고도 부르며, 그래프에서 가까운 노드부터 우선적으로 탐색하는 알고리즘
- BFS는 큐 자료구조를 이용하며, 구체적인 동작 과정은 다음과 같음
- 탐색 시작 노드를 큐에 삽입하고 방문 처리
- 큐에서 노드를 꺼낸 뒤에 해당 노드의 인접 노드 중에서 방문하지 않은 노드를 모두 큐에 삽입하고 방문처리
- 더이상 2번의 과정을 수행할 수 없을 때까지 반복
5. BFS 동작 예시
- [Step 1] 그래프를 준비 (시작노드 : 1)
- [Step 2] 시작 노드인 '1'을 큐에 삽입하고 방문처리
- [Step 3] 큐에서 노드 '1'을 꺼내 방문하지 않은 인접 노드 '2','3','8'을 큐에 삽입하고 방문 처리
- [Step 4] 큐에서 노드 '2'를 꺼내 방문하지 않은 인접 노드 '7'을 큐에 삽입하고 방문 처리
- [Step 5] 큐에서 노드 '3'을 꺼내 방문하지 않은 인접 노드 '4','5'를 큐에 삽입하고 방문 처리
- [Step 6] 큐에서 노드 '8'을 꺼내고 방문하지 않은 인접 노드가 없으므로 무시
- 이 과정 반복
- 이러한 과정을 반복하여 전체 노드의 탐색 순서(큐에 들어간 순서)는 다음과 같음
- 탐색 순서 : 1 -> 2 -> 3 -> 8 -> 7 -> 4 -> 5 ->6
6. BFS 코드 구현
'자료구조 C++' 카테고리의 다른 글
크루스칼 (0) | 2021.04.04 |
---|---|
그리디 알고리즘 (0) | 2021.03.05 |
동적 프로그래밍(Dynamic Programming) - DP (0) | 2021.02.13 |
9. 우선 순위 큐 (Heap) (0) | 2021.02.07 |
8. 이진 탐색 트리 (binary search tree) (0) | 2021.02.03 |