일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 자료구조
- DirectX12
- Direct12
- 다이나믹프로그래밍
- 렌더링 파이프라인
- 락
- 병행성
- 컨디션 변수
- 다이나믹 프로그래밍
- 알고리즘
- OS
- 운영체제
- 프로그래머스
- 병행성 관련 오류
- I/O장치
- 파일시스템 구현
- 디자인패턴
- 멀티프로세서
- directx
- 스케줄링
- DirectX 12
- 백준
- 그리디 알고리즘
- 그리디알고리즘
- 동적계획법
- 타입 객체
- 멀티쓰레드
- 영속성
- 쓰레드
- codility
Archives
- Today
- Total
기록공간
너비 우선 탐색 (BFS) 본문
반응형
너비 우선 탐색 (Breadth Firest Search : BFS)은 그래프의 모든 정점들을 특정한 순서에 따라 방문하는 알고리즘 중 하나이다. 현재 정점과 인접한 모든 간선을 우선적으로 검사하며, 그 중 방문하지 않은 정점을 찾아 순차적으로 방문해 나아간다.
더이상 방문할 수 없을때 까지 반복하며, 인접한 간선을 우선적으로 검사하기 위하여 Queue를 사용한다. 어떻게 진행되는지를 그림을 통해 살펴보자.
1을 방문하면서 인접한 정점인 2, 3, 그리고 7을 큐에 넣어준다. 그리고 큐에 들어간 순서대로 방문하면서 큐가 빌때까지 반복 수행해준다. 이 작업을 모든 정점이 방문되었을때까지 반복해주면 된다.
구현
위 그래프 정보를 바탕으로 깊이 탐색을 구현해보자.
#include <iostream>
#include <vector>
#include <algorithm>
#include <queue>
#define VISITED 1
#define UNVISITED 0
#define CONNECTED 1
using namespace std;
// 인접행렬로 간선을 표현한것
vector<vector<int>> edge =
{
{0, 1, 1, 0, 0, 0, 0},
{1, 0, 0, 1, 1, 0, 0},
{1, 0, 0, 0, 0, 0, 1},
{0, 1, 0, 0, 0, 1, 0},
{0, 1, 0, 0, 0, 1, 0},
{0, 0, 0, 1, 1, 0, 1},
{0, 0, 1, 0, 0, 1, 0}
};
vector<int> vertices;
// 너비 우선 탐색
void BFS(int index)
{
// 정점에 대해 방문처리를 한다.
vertices[index] = VISITED;
// 정점 정보를 큐에 넣는다.
queue<int> q;
q.push(index);
cout << index + 1 << " ";
// 큐가 빌때까지 반복한다.
while (false == q.empty())
{
// 큐에 들어간 정점 정보 순서대로 방문이 가능한지 반복한다.
int sub_index = q.front();
q.pop();
for (size_t i = 0; i < edge.size(); ++i)
{
// 연결되어 있고 방문한 적이 없는 정점이 있는 경우
if (CONNECTED == edge[i][sub_index] &&
UNVISITED == vertices[i])
{
cout << i + 1 << " ";
q.push(i);
vertices[i] = VISITED;
}
}
}
}
int main()
{
vertices = vector<int>(edge.size(), UNVISITED);
// 모든 정점을 방문할 때까지 너비 우선탐색을 반복한다.
for (size_t i = 0; i < edge.size(); ++i)
{
if (UNVISITED == vertices[i])
BFS(i);
}
cout << endl;
}
출력값
1 2 3 4 5 7 6
반응형
'Algorithm > 이론' 카테고리의 다른 글
크러스컬 알고리즘 (Kruskal Algorithm) (0) | 2020.06.17 |
---|---|
최장증가수열 - LIS(Longest Increasing Subsequence) (0) | 2020.02.17 |
동적계획법(Dynamic Programming) (0) | 2020.02.17 |
깊이 우선 탐색 (DFS) (0) | 2020.02.09 |
그리디 알고리즘 (Greedy Algorithm) (0) | 2020.02.08 |
Comments