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
- Spring Cloud Feign
- retry
- Intellj
- 페이징
- JPA
- DP
- 알고리즘
- 코딩
- Jenkins
- 데이터베이스
- golang
- 오라클
- Kafka
- Spring Cloud
- 자바
- 백준
- SQL
- 클라우드
- 운영체제
- feign
- aws
- db
- PL/SQL
- 디자인 패턴
- Spring
- MVC
- 자료구조
- MST
- 쿼리
- Spring Boot
Archives
- Today
- Total
justgo_developer
크루스칼 알고리즘(Kruskal's Algorithm) 본문
728x90
반응형
크루스칼 알고리즘(Kruskal's Algorithm)
- 에지들을 가중치의 오름차순으로 정렬한다.
- 에지들을 그 순서대로 하나씩 선택해간다. 단, 이미 선택된 에지들과 사이클을 형성하면 선택하지 않는다.
- n-1개의 에지가 선택되면 종료한다.
노드가 9개이므로 에지가 8개까지만 하면 된다.
더하면 사이클이 생김.
◆ 사이클 검사
- 초기 상태 : 선택된 에지 없음
- 각각의 연결요소를 하나의 집합으로 표현
{a} {b} {c} {d} {e} {f} {g} {h} {i}
MST-KRUSKAL(G, w)
A<-
for each vertex v ∈ V[G]
do MAKE-SET(v) //각각의 노드들을 유일한 원소로 가지는 집합들을 만든다.
sort the edges of E into nondecreasing order by weight w
//모든 에지에 대해서 가중치에따라 오름차순으로 정렬
for each edge(u,v) ∈ E, taken in nondecreasing order by weight
do if FIND-SET(u) ≠ FIND-SET(v) //노드 v가 속한 집합을 찾아라
then A<- A∪{(u,v)}
UNION(u,v) //u와v가 속한 두집합을 하나로 합친다.
return A
728x90
반응형
'IT > 알고리즘' 카테고리의 다른 글
그리디(Greedy) (0) | 2018.02.09 |
---|---|
최소 스패닝 트리(Minimum Spanning Tree, MST) (0) | 2018.02.07 |
플로이드 워셜 알고리즘(Floyd-Warshall) (0) | 2018.02.01 |
벨만-포드 알고리즘(Bellman-Ford Algorithm) (0) | 2018.02.01 |
다익스트라 알고리즘(Dijkstra) (0) | 2018.01.31 |