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
- 알고리즘
- dbms
- 개발자취업
- 가상컴퓨팅
- Java
- python
- js
- 항해99
- 코테
- 자료구조
- data structure
- dfs
- DB
- 코딩테스트준비
- generic class
- 암호학
- 생성자
- 크루스칼
- 공개키 암호화
- Algorithm
- Queue
- jsp
- 문자열
- 코딩테스트
- 자바의정석
- javascript
- spring
- BFS
- JPA
- sql
Archives
- Today
- Total
PLOD
[Algorithm] Minimum Spanning Tree(최소 신장 트리) 본문
computer science/Algorithm | Datastructure
[Algorithm] Minimum Spanning Tree(최소 신장 트리)
훌룽이 2024. 8. 4. 12:23MST
하나의 그래프가 있을 때 모든 노드를 포함하면서 사이클이 존재하지 않는 부분 그래프를 의미한다. 이때 모든 노드가 포함되어 서로 연결되면서 사이클이 존재하지 않는다는 조건은 트리의 성립 조건이기도 하다. 최소 길이의 간선으로 모든 노드들을 연결해야 되는 문제가 나올 때 최소 신장 트리 알고리즘을 사용 할 수 있다.
Kruskal Algorithm
크루스칼 알고리즘은 대표 적인 최소 신장 트리 알고리즘이다. 크루스칼 알고리즘은 greedy algorithm(탐욕 기법)에 속한다. 먼저 모든 간선에 대하여 정렬을 수행한 뒤에 가장 거리가 짧은 간선부터 집합에 포함시키면 된다. Kruskal 알고리즘은 간선을 정렬하는데 시간이 가장 오래 걸리기 때문에 간선의 개수가 E 일때, O(ElogE)의 시간 복잡도를 가진다.
(1) 간선 데이터를 비용에 따라 오름차순으로 정렬한다.
(2) 간선을 하나씩 확인하며 현재의 간선이 cycle을 발생시키는지 확인한다.
Ⅰ. 사이클이 발생하지 않는 경우 최소 신장 트리에 포함시킨다.
Ⅱ. 사이클이 발생하는 경우 최소 신장 트리에 포함시키지 않는다.
(3) 모든 간선에 대하여 (2)번의 과정을 반복한다.
def find_parent(parent,x) :
if parent[x] != x :
parent[x] = find_parent(parent,parent[x])
return parent[x]
def union_parent(parent,a,b) :
a = find_parent(parent,a)
b = find_parent(parent,b)
if a < b :
parent[b] < a
else :
parent[a] = b
v,e = map(int,input().split())
result = 0
edges = []
parent = [0] * (v+1)
for i in range(1,v+1) :
parent[i] = i
for _ in range(e) :
a,b,cost = map(int,input().split())
edges.append((cost,a,b))
edges.sort()
for edge in edges :
cost, a , b = edge
if find_parent(parent,a) != find_parent(parent,b) :
union_parent(parent,a,b)
result += cost
print(result)
* tree와 graph의 차이
그래프 | 트리 | |
방향성 | 방향 그래프 혹은 무방향 그래프 | 방향 그래프 |
순환성 | 순환 및 비순환 | 비순환 |
루트 노드 존재 여부 | 루트 노드가 없음 | 루트 노드가 존재 |
노드 간 관계성 | 부모와 자식 관계 없음 | 부모와 자식 관계 |
모델의 종류 | 네트워크 모델 | 계층 모델 |
'computer science > Algorithm | Datastructure' 카테고리의 다른 글
[Algorithm] Topology sort(위상 정렬) (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