자료 구조 - 그래프 순회, 그래프 탐색 (너비 우선 탐색 BFS)
1. 너비 우선 탐색 (Breadth First Search : BFS)
1) 순회 방법
- 시작 정점으로부터 인접한 정점들을 모두 차례로 방문하고 나서, 방문했던 정점을 시작으로 하여 다시 인접한
정점들을 차례로 방문하는 방식
- 가까운 정점들을 먼저 방문하고 멀리 있는 정점들은 나중에 방문하는 순회방법
- 인접한 정점들에 대해서 차례로 다시 너비 우선 탐색을 반복해야 하므로 선입선출의 구조를 갖는 큐를 사용
2) 너비 우선 탐색 알고리즘
BFS(v)
for(i <- 0; i<n; i <- i+1) do{
visited[i] <- false;
}
Q <- createQueue();
visited[v] <- true;
v 방문;
while(not isEmpty(Q)) do{
while(visited[v의 인접 정점 w] = false) do{
visitied[w] <- true;
w 방문;
enQueue(Q,w);
}
v <- deQueue(Q);
}
end BFS()
3) 너비 우선 탐색 예
(1) 초기상태 : 배열 visited를 False로 초기화하고, 공백 큐를 생성
data:image/s3,"s3://crabby-images/f07ad/f07ad211414b54abb3dbcad9c9404c6c5f9e51de" alt="alt"
(2) 정점 A를 시작으로 너비 우선 탐색을 시작함
visited[A] <- true;
A 방문;
data:image/s3,"s3://crabby-images/552ff/552ff0fe60150a51821069cd6086377cf800a8b7" alt="alt"
(3) 정점 A의 방문 안한 모든 인접정점 B,C 방문
- 정점 A의 방문 안 한 모든 인접 정점 B,C를 방문하고, 큐에 enQueue함
visited[(A의 방문 안한 인접정점 B와 C)]
<- true;
- (A의 방문 안한 인접정점 B와 C) 방문
- enQueue(Q, (A의 방문 안한 인접 정점 B와 C));
data:image/s3,"s3://crabby-images/a5072/a50728639bc86f3d05768e70dbae4a9b0d8eb4e4" alt="alt"
(4) 정점 A에 대한 인접정점들을 처리했으므로
- 너비 우선 탐색을 계속할 다음 정점을 찾기 위해 큐를 deQueue하여 정점 B를 구함
data:image/s3,"s3://crabby-images/75979/7597960bd4eadea563d32c19095edd030fc37aae" alt="alt"
(5) 정점 B의 방문 안한 모든 인접정점 D,E 방문
- 정점 B의 방문 안 한 모든 인접 정점 D,E를 방문하고, 큐에 enQueue함
visited[(B의 방문 안한 인접정점 D와 E)]
<- true;
- (B의 방문 안한 인접정점 D와 E) 방문
- enQueue(Q, (B의 방문 안한 인접 정점 D와 E));
data:image/s3,"s3://crabby-images/0dd82/0dd82dff950b5435c6ed8927b6b24d125dc29325" alt="alt"
(6) 정점 B에 대한 인접정점들을 처리했으므로
- 너비 우선 탐색을 계속할 다음 정점을 찾기 위해 큐를 deQueue하여 정점 C를 구함
data:image/s3,"s3://crabby-images/06c29/06c29ffce5c44dcf78aac01c541cf7de14eaecc2" alt="alt"
(7) 정점 C에는 방문 안한 인접정점이 없으므로
- 너비 우선 탐색을 계속할 다음 정점을 찾기 위해 큐를 deQueue하여 정점 D를 구함
data:image/s3,"s3://crabby-images/0eb82/0eb82a4cc70361e2a2625b5d4505ab5a450ea196" alt="alt"
(8) 정점 D의 방문 안한 모든 인접정점 G 방문
- 정점 D의 방문 안 한 모든 인접 정점 G를 방문하고, 큐에 enQueue함
visited[(D의 방문 안한 인접정점 G)]
<- true;
- (D의 방문 안한 인접정점 G) 방문
- enQueue(Q, (D의 방문 안한 인접 정점 G));
data:image/s3,"s3://crabby-images/2f442/2f442e980739c418efb9bf35685ba740cbc73ecf" alt="alt"
(9) 정점 D에 대한 인접정점들을 처리했으므로
- 너비 우선 탐색을 계속할 다음 정점을 찾기 위해 큐를 deQueue하여 정점 D를 구함
data:image/s3,"s3://crabby-images/6cd84/6cd840149b011b42cf6dd0b064e5e62054c31b95" alt="alt"
(10) 정점 E에는 방문 안한 인접정점이 없으므로
- 너비 우선 탐색을 계속할 다음 정점을 찾기 위해 큐를 deQueue하여 정점 G를 구함
data:image/s3,"s3://crabby-images/61037/6103740314d482ffc570ea676faaba867c8b0637" alt="alt"
(11) 정점 G의 방문 안한 모든 인접정점 F 방문
- 정점 G의 방문 안 한 모든 인접 정점 F를 방문하고, 큐에 enQueue함
visited[(G의 방문 안한 인접정점 F)]
<- true;
- (G의 방문 안한 인접정점 F) 방문
- enQueue(Q, (G의 방문 안한 인접 정점 F));
data:image/s3,"s3://crabby-images/63125/631256f3b3b790d46ba29c1062678eb52ba1a1f3" alt="alt"
(12) 정점 G에 대한 인접정점들을 처리했으므로
- 너비 우선 탐색을 계속할 다음 정점을 찾기 위해 큐를 deQueue하여 정점 F를 구함
data:image/s3,"s3://crabby-images/d6822/d6822124db9ca05140622563e054e34d0b829eea" alt="alt"
(13) 정점 F에는 방문 안한 인접정점이 없으므로
- 너비 우선 탐색을 계속할 다음 정점을 찾기 위해 큐를 deQueue해야 하는데
- 큐가 공백이므로 너비 우선 탐색을 종료함,
data:image/s3,"s3://crabby-images/d1d4e/d1d4e4d1b043607e0b623d2faedb52477fd1b414" alt="alt"
댓글남기기