Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 정렬
- uuid-ossp
- adminbro
- 엣지컴퓨팅
- 동료학습
- 어셈블리
- 쿠버네티스
- 부동소수점
- 이노베이션아카데미
- 텍스트북
- 스플릿키보드
- SFINAE
- schema first
- enable_if
- mistel키보드
- GraphQL
- psql extension
- 창업
- 스타트업
- c++
- 42seoul
- 프라이빗클라우드
- Cloud Spanner
- 도커
- raycasting
- 42서울
- 어셈블리어
- 파이썬
- 자료구조
- 레이캐스팅
Archives
- Today
- Total
written by yechoi
그래프 - 너비우선 탐색(bfs) 본문
반응형
너비우선탐색(Breadth First Search)
- 너비를 우선으로 하여 탐색을 수행하는 알고리즘
- DFS와 마찬가지로 맹목적으로 전체 노드를 탐색하고자 할 때 사용
- 큐(Queue) 자료구조에 기초
- 구현 시 큐 STL(라이브러리)을 사용하면 좋고, 탐색에는 O(N)의 시간이 소요
- 수행시간은 DFS보다 좋은 편
동작원리
- 탐색 시작 노드를 큐에 삽입하고 방문처리
- 큐에서 노드를 꺼내 해당 노드의 인접 노드 중에서 방문하지 않은 노드들을 모두 큐에 삽입하고 방문처리
- 2번의 과정을 더 이상 수행할 수 없을 때까지 반복
구현 (아래 코드는 방문 순서에 대한 규칙이 없음)
#include <stdio.h>
#include <stdlib.h>
#define INF 99999999
#define MAX_SIZE 1001
typedef struct {
int index;
struct Node *next;
} Node;
typedef struct {
Node *front;
Node *rear;
int count;
} Queue;
Node **a;
int n, m, c[MAX_SIZE];
void addFront(Node *root, int index)
{
Node *node = (Node *)malloc(sizeof(Node));
node->index = index;
node->next = root->next;
root->next = node;
}
void queuePush(Queue *queue, int index)
{
Node *node = (Node *)malloc(sizeof(Node));
node->index = index;
node->next = NULL;
if (queue->count == 0)
queue->front = node;
else
queue->rear->next = node;
queue->rear = node;
queue->count++;
}
int queuePop(Queue *queue)
{
if (queue->count == 0)
{
printf("Queue Underflow!\n");
return -INF:
}
Node *node = queue->front;
int index = node->index;
queue->front = node->next;
free(node);
queue->count--;
return (index);
}
void bfs(int start)
{
Queue q;
q.front = q.rear = NULL;
q.count = 0;
queuePush(&q, start);
c[start] = 1;
while (q.count != 0)
{
int x = queuePop(&q);
printf("%d ", x);
Node *cur = a[x]->next;
while (cur != NULL)
{
int next = cur->index;
if (!c[next])
{
queuePush(&q, next);
c[next] = 1;
}
cur = cur->next;
}
}
}
int main(void)
{
scanf("%d %d", &n, &m);
a = (Node **)malloc(sizeof(Node *) * MAX_SIZE);
for (int i = 1 ; i <= n ; i++)
{
a[i] = (Node *)malloc(sizeof(Node));
a[i]->next = NULL;
}
for (int i = 0 ; i < m ; i++)
{
int x, y;
scanf("%d %d", &x, &y);
addFront(a[x], y);
addFront(a[y], x);
}
bfs(1);
system("pause");
return (0);
}
반응형