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
- js
- 코딩테스트준비
- Algorithm
- python
- JPA
- generic class
- 자료구조
- 알고리즘
- Queue
- dfs
- DB
- 크루스칼
- 개발자취업
- 가상컴퓨팅
- 코딩테스트
- sql
- dbms
- Java
- spring
- 문자열
- 코테
- 암호학
- 자바의정석
- 항해99
- jsp
- BFS
- 생성자
- 공개키 암호화
- javascript
- data structure
Archives
- Today
- Total
PLOD
[Algorithm] Topology sort(위상 정렬) 본문
위상정렬
위상정렬은 정렬 알고리즘의 일종이다. 이상 정렬은 순서가 정해져 있는 일련의 작업을 차례대로 수행해야 할 때 사용 할 수 있는 알고리즘이다. 즉, 위상정렬은 방향 그래프의 모든 노드를 방향성에 거스르지 않도록 순서대로 나열하는 것이다.
위상 정렬 알고리즘을 사용하기 위해서는 진입 차수(degree) 부터 알아야한다. 진입차수란 특정한 노드로 들어오는 간선의 개수를 의미한다. 진입차수를 이용하여 위상정렬을 하는 방법은 다음과 같다.
1. 진입차수가 0인 노드를 queue에 넣는다.
2. 큐가 빌 때까지 다음의 과정을 반복한다.
Ⅰ. 큐에서 원소를 꺼내 해당 노드에서 출발하는 간선을 그래프에서 제거한다.
Ⅱ. 새롭게 진입차숙 0이 된 노드를 queue에 넣는다.
위상 정렬의 시간 복잡도는 O(V+E)이다. 위상 정렬을 수행 할 떄는 차례대로 모든 노드를 확인하면서, 해당 노드에서 출발 하는 간선을 차례대로 제거해야 된다.
'computer science > Algorithm | Datastructure' 카테고리의 다른 글
[Algorithm] Minimum Spanning Tree(최소 신장 트리) (0) | 2024.08.04 |
---|---|
[Algorithm] 투포인터(Two pointers) (0) | 2024.07.18 |
[Algorithm] Brute-force(완전탐색) , Backtracking(백트래킹) (0) | 2023.07.31 |
[Algorithm] Shortest path(최단 경로) (0) | 2023.07.12 |
[Algorithm] 동적계획법(Dynamic Programming : DP) (0) | 2023.07.06 |
Comments