| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 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 |
Tags
- 프론트엔드
- Python
- c언어
- 해시
- 정글
- 혼자 공부해서 개발까지
- 프론트앤드
- BFS
- 알고리즘
- HTML기초
- javascript
- html
- 정렬
- Git
- DFS
- 그래프
- frontend
- 백준
- Mini-React
- 개발자
- react
- 알고리즘 기초
- 그리디
- 크래프톤 정글
- 팀프로젝트
- 프로그래머스
- CSS
- 코딩테스트
- 코딩
- js
Archives
- Today
- Total
민혁이의 IT스토리
알고리즘 기초 - 너비 우선 탐색(BFS) 본문
BFS란?
- 그래프 탐색 알고리즘 중 하나로, 시작 정점에서 가까운 노드부터 차례대로 탐색해 나가는 방식입니다.
- 즉, "넓게 퍼져나가듯" 탐색한다고 해서 너비 우선 탐색이라고 부릅니다.
동작 원리
- 시작 노드를 큐(Queue)에 넣는다.
- 큐에서 노드를 꺼내서 방문한다.
- 방문한 노드의 인접한 노드들을 모두 큐에 넣는다.
- 큐가 빌 때까지 2~3 과정을 반복한다.
BFS의 특징
큐(Queue) 사용: FIFO 구조로 탐색 순서를 보장
가까운 노드부터 탐색: 레벨별 탐색이 가능
최단 경로 탐색에 유리: 가중치가 없는 그래프에서 최단 거리를 찾을 때 많이 사용
마무리
BFS는 그래프나 트리에서 가장 기본적인 탐색 알고리즘으로,
큐를 활용해 가까운 노드부터 차례대로 탐색하는 방식입니다.
특히 최단 거리 문제에서 매우 유용하게 사용되므로 꼭 알아두어야 합니다!
'알고리즘' 카테고리의 다른 글
| 알고리즘 기초 - 동적 프로그래밍(Dynamic Programming, DP) (0) | 2025.09.26 |
|---|---|
| 알고리즘 기초 - 위상정렬 (0) | 2025.09.26 |
| 알고리즘 기초 - 깊이 우선 탐색(DFS) (0) | 2025.09.24 |
| 알고리즘 기초 - 그래프 종류/ 표현 방식 (0) | 2025.09.22 |
| 알고리즘 기초 - 해시 테이블 (0) | 2025.09.22 |