이진 트리의 넓이 우선 순회 (BFS: Breadth First Traversal)
원칙
- 수준(Level)이 낮은 노드를 우선으로 방문
- 같은 수준의 노드를 사이에는 부모 노드의 방순 순서에 따라 방문(왼 > 오)
data:image/s3,"s3://crabby-images/a82d6/a82d64804149051c58b51bced7e20b46ae5f96a0" alt="image-20210422203246621"
순회의 결과: A -> B -> C -> D -> E ... J
넓이 우선 순회 흐름 설계
data:image/s3,"s3://crabby-images/17a25/17a253d985d255f7bec2cb29437b3231b9da757f" alt="img"
- 수준이 낮은 노드 부터 방문해서 큐에 enqueue
data:image/s3,"s3://crabby-images/84174/841745ee3850c190b3d0b84a4ae51d54b53be3f1" alt="img"
data:image/s3,"s3://crabby-images/119b9/119b91fb849c66fd7bee5f6a3966c2e713b855e9" alt="img"
data:image/s3,"s3://crabby-images/2041f/2041fda2c841d4e4e5935305147eac1a14692eb4" alt="img"
data:image/s3,"s3://crabby-images/44fd5/44fd5ba0d4987ab094f8cb5912f836125a452600" alt="img"
data:image/s3,"s3://crabby-images/c4a7e/c4a7eebef0292a7f05e92f63d4e916feacf164fc" alt="img"
data:image/s3,"s3://crabby-images/8a89c/8a89c3a919d7cdf6b2dff6bbe4765e9f1969b243" alt="img"
data:image/s3,"s3://crabby-images/ea09e/ea09eee8d8b6406a59b8e2cb838e335cc9df709b" alt="img"
data:image/s3,"s3://crabby-images/c20e9/c20e908ec8a424dbfbf40f4f281c16d83cce44c1" alt="img"
data:image/s3,"s3://crabby-images/c38f7/c38f70779ac42841e878ddc839ced9065836ccfe" alt="img"
- E를 방문(E를 dequeue), E의 자식노드는 없음
data:image/s3,"s3://crabby-images/c5160/c51605ea97c5cc92d7b728aed2ca62d68e5eab67" alt="img"
data:image/s3,"s3://crabby-images/86191/86191dae89f5a8a4bcd512d883235f9a90937228" alt="img"
data:image/s3,"s3://crabby-images/5db96/5db96a429785af5b7f0d22236284e940d362b9e4" alt="img"
- G를 방문(G를 dequeue), G의 자식노드 없음
data:image/s3,"s3://crabby-images/0af45/0af45d4ac51e099c77de4dca4ecd1b2cb81b379a" alt="img"
- H를 방문(H를 dequeue), H의 자식노드 없음
data:image/s3,"s3://crabby-images/e4c81/e4c81f28e13c868ddb9244d0d97a2b9786606226" alt="img"
- I를 dequeue(I를 방문), I의 자식노드 없음, 큐가 비어있으면 순회 끝.
넓이 우선 순회 알고리즘 구현
- traversal에는 빈 리스트를 초기화, q에는 빈 큐를 초기화한다.
- 빈 트리가 아니면, root node를 큐에 추가(enqueue)한다
- q가 비어있지 않는 동안
- q의 원소를 추출하여(dequeue) node에 저장한다
- node를 방문 처리(traversal에 append)한다
- node의 왼쪽, 오른쪽 자식 노드가 있으면 q에 추가한다
- q가 비어있는 큐가 되면 모든 노드 방문 완료하였음으로 traversal를 리턴한다