SlideShare a Scribd company logo
1 of 38
Download to read offline
서울시립대 알고리즘 소모임
최소 스패닝 트리
2학기 2주차
강의자 소개
2020 AL林 정기 스터디 2
이름 최문기
소속 서울시립대 컴퓨터과학부(16학번)
핸들 iknoom1107(BOJ) IKnoom(Codeforces) IKnoom(AtCoder)
ICPC 팀 ManManChiAnunTeam
- 김정현, 최문기, 최연웅
공지 : ICPC
2020 AL林 정기 스터디 3
2020 한국 대학생 프로그래밍 대회 / ACM-ICPC 예선 등록
9월 7일(월) ~ 9월 24일(목)
2020 AL林 정기 스터디 4
최소 스패닝 트리
스패닝 트리 (spanning tree, 신장 트리)
2020 AL林 정기 스터디 5
정점이 V개이고 간선이 E개인
무향 연결 그래프에서
간선을 V – 1개만 남겨 트리가 되도록 만든 것
(V – 1 : 최소 개수의 간선)
스패닝 트리 (spanning tree, 신장 트리)
2020 AL林 정기 스터디 6
스패닝 트리 (spanning tree, 신장 트리)
2020 AL林 정기 스터디 7
스패닝 트리는 한가지가 아닙니다.
BFS 또는 DFS로 만들어지는 트리도 스패닝 트리입니다.
최소 스패닝 트리 (Minimum spanning tree, 최소 신장 트리)
2020 AL林 정기 스터디 8
간선의 가중치의 합이 가장 작은 스패닝 트리
→ 그래프에 있는 모든 정점을 연결하기 위한 최소 비용
최소 스패닝 트리 (Minimum spanning tree, 최소 신장 트리)
2020 AL林 정기 스터디 9
최소 스패닝 트리를 찾는 알고리즘
✓ 프림 알고리즘
✓ 크루스칼 알고리즘
둘 다 그리디 알고리즘입니다.
최소 스패닝 트리 (Minimum spanning tree, 최소 신장 트리)
2020 AL林 정기 스터디 10
간선이 하나도 없는 상태에서 시작해서
가중치가 작은 간선을 하나씩 추가해 가는 그리디 알고리즘
프림 : 간선이 없는 상태 → 하나의 트리 → 하나의 스패닝 트리
크루스칼 : 간선이 없는 상태 → 여러개의 트리 → 하나의 스패닝 트리
두 알고리즘 모두 같은 방법으로 정당성을 증명합니다.
2020 AL林 정기 스터디 11
프림 알고리즘
프림 알고리즘(Prim's algorithm)
2020 AL林 정기 스터디 12
간선이 하나도 없는 상태에서 시작해서
가중치가 작은 간선을 하나씩 추가해 가는 그리디 알고리즘
- 하나의 정점 집합(트리)에서 점점 확장하는 방법
- 집합(트리)에 정점을 하나 더할 때마다 간선이 하나씩 확정된다.
- 모든 정점을 포함할 때까지 반복한다.
프림 알고리즘(Prim's algorithm)
2020 AL林 정기 스터디 13
https://en.wikipedia.org/wiki/Prim%27s_algorithm#/media/File:PrimAlgDemo.gif
프림 알고리즘(Prim's algorithm)
2020 AL林 정기 스터디 14
어떻게 구현할까요?
다익스트라 알고리즘과 유사하게 구현합니다.
다익스트라 알고리즘 : O(V2)
2020 AL林 정기 스터디 15
더 구체적으로 봅시다.
s : 시작점, weight[][] : 가중치 인접 행렬
distance = [∞, ∞, ..., ∞]
found = [False, False, ..., False]
distance[s] = 0
found[s] = True
for (s에 인접한 정점 u에 대해서) {
distance[u] = weight[s][u]
}
다익스트라 알고리즘 : O(V2)
2020 AL林 정기 스터디 16
더 구체적으로 봅시다.
for (V – 1번 반복) {
u = (found[u]가 False이면서 distance가 가장 작은 정점)
found[u] = True
for (u에 인접한 정점 v에 대해서) {
if (distance[v] > distance[u] + weight[u][v])
distance[v] = distance[u] + weight[u][v])
}
}
return distance
프림 알고리즘(Prim's algorithm) : O(V2)
2020 AL林 정기 스터디 17
while (모든 정점을 포함할 때까지) {
새로운 정점을 포함시키는
가장 가중치가 작은 간선을 선택한다.
}
프림 알고리즘(Prim's algorithm) : O(V2)
2020 AL林 정기 스터디 18
s : 시작점, weight[][] : 가중치 인접 행렬
minWeight = [∞, ∞, ..., ∞]
found = [False, False, ..., False]
minWeight[s] = 0
프림 알고리즘(Prim's algorithm) : O(V2)
2020 AL林 정기 스터디 19
for (V – 1번 반복) {
u = (found[u]가 False이면서 minWeight가 가장 작은 정점)
found[u] = True
for (u에 인접한 정점 v에 대해서) {
if (minWeight[v] > weight[u][v])
minWeight[v] = weight[u][v]
}
}
프림 알고리즘(Prim's algorithm) : O(ElogV)
2020 AL林 정기 스터디 20
s : 시작점, weight[][] : 가중치 인접 리스트, priority_queue : 최소 힙
minWeight = [∞, ∞, ..., ∞]
found = [False, False, ..., False]
minWeight[s] = 0
priority_queue ← {0, s} // {가중치, 정점 번호}
프림 알고리즘(Prim's algorithm) : O(ElogV)
2020 AL林 정기 스터디 21
while (priority_queue is not empty) {
u = priority_queue.pop() // 가중치가 가장 작은 간선
if (found[u] = True) continue;
found[u] = True
for (u에 인접한 정점 v에 대해서) {
w ← (u, v)의 가중치
if (minWeight[v] > w){
minWeight[v] = w
priority_queue.push( {minWeight[v], v} )
}
}
}
프림 알고리즘(Prim's algorithm) : O(ElogV)
2020 AL林 정기 스터디 22
def Prim(s):
found = [False] * V
min_weight = [INF] * V
sum_weight = 0
min_weight[s] = 0
hq = [(0, s)]
while len(hq) > 0:
weight, u = heapq.heappop(hq)
if found[u]: continue
found[u] = True
sum_weight += weight
for v, w in adj[u]:
if min_weight[v] > w:
min_weight[v] = w
heapq.heappush(hq, (min_weight[v], v))
return sum_weight
소스코드 : http://boj.kr/6114c880a073475e80c7da1f03150562
2020 AL林 정기 스터디 23
크루스칼 알고리즘
크루스칼 알고리즘(Kruskal's algorithm)
2020 AL林 정기 스터디 24
간선이 하나도 없는 상태에서 시작해서
가중치가 작은 간선을 하나씩 추가해 가는 그리디 알고리즘
- 여러 개의 집합(트리)에서 점점 확장하는 방법
- 집합(트리)과 집합(트리)를 합칠 때마다 간선이 하나씩 확정된다.
- 하나의 집합(트리)가 될 때까지 반복한다.
크루스칼 알고리즘(Kruskal's algorithm)
2020 AL林 정기 스터디 25
https://en.wikipedia.org/wiki/Kruskal%27s_algorithm#/media/File:KruskalDemo.gif
크루스칼 알고리즘(Kruskal's algorithm)
2020 AL林 정기 스터디 26
while (모든 정점이 하나의 집합이 될 때까지) {
서로 다른 집합을 연결하는
가장 가중치가 작은 간선을 선택한다.
}
크루스칼 알고리즘(Kruskal's algorithm)
2020 AL林 정기 스터디 27
간선을 가중치 순으로 정렬한다.
while (V – 1개의 간선을 포함할 때까지) {
현재 간선 (u, v)에 대해서
if (u와 v가 다른 집합에 속하면) {
간선 (u, v)를 포함시킨다.
}
}
크루스칼 알고리즘(Kruskal's algorithm)
2020 AL林 정기 스터디 28
1 (a, b)
1 (a, c)
1 (b, c)
3 (a, d)
3 (c, d)
a b
d c
1
1
1
3
3
크루스칼 알고리즘(Kruskal's algorithm)
2020 AL林 정기 스터디 29
두 정점이 다른 집합에 속해 있는지 확인하는 방법
→ 분리 집합의 처리 (Union-Find)
크루스칼 알고리즘(Kruskal's algorithm)
2020 AL林 정기 스터디 30
소스코드 : http://boj.kr/03ced5904c3a4d4ea16b9db00e55587e
def find(a):
if p[a] != a: p[a] = find(p[a])
return p[a]
def union(a, b):
p[find(a)] = find(b)
if __name__ == "__main__":
n, m = map(int, input().split())
p = [i for i in range(n)]
edges = []
for _ in range(m):
u, v, w = map(int, input().split())
edges.append((w, u - 1, v - 1))
크루스칼 알고리즘(Kruskal's algorithm)
2020 AL林 정기 스터디 31
# Kruskal's algorithm
edges.sort()
count = 0
MST = 0
for w, u, v in edges:
if find(u) != find(v):
union(u, v)
MST += w
count += 1
if count == n - 1:
break
print(MST)
크루스칼 알고리즘(Kruskal's algorithm)
2020 AL林 정기 스터디 32
정렬하고 나서 while문은 아무리 많아봤자 O(E)번 수행합니다.
두 정점이 같은 집합인지 확인하는데 O(log*V)입니다.
따라서 크루스칼 알고리즘의 시간복잡도는 O(ElogE) 입니다.
(전체 과정 중 간선을 정렬하는 시간복잡도가 제일 큽니다.)
2020 AL林 정기 스터디 33
정당성
정당성
2020 AL林 정기 스터디 34
1. 탐욕적 선택의 안정성(최적해가 됨)을 증명
2. 매트로이드 이론의 관점에서의 증명
정당성
2020 AL林 정기 스터디 35
정당성
2020 AL林 정기 스터디 36
연습 문제
2020 AL林 정기 스터디 37
최소 스패닝 트리
1197 최소 스패닝 트리
1647 도시 분할 계획
2887 행성 터널
출처
2020 AL林 정기 스터디 38
https://en.wikipedia.org/

More Related Content

What's hot

Numerical Method
Numerical MethodNumerical Method
Numerical MethodULUG
 
그래프의 최단 경로 찾기
그래프의 최단 경로 찾기그래프의 최단 경로 찾기
그래프의 최단 경로 찾기Jung-Ho Kim
 
Graph
GraphGraph
GraphGNGLB
 
DP Optimization
DP OptimizationDP Optimization
DP Optimization승혁 조
 
The Art of Computer Programming 2.3.2 Tree
The Art of Computer Programming 2.3.2 TreeThe Art of Computer Programming 2.3.2 Tree
The Art of Computer Programming 2.3.2 Treehyun soomyung
 
CS294-112 Lecture 06
CS294-112 Lecture 06CS294-112 Lecture 06
CS294-112 Lecture 06Gyubin Son
 
밑바닥부터시작하는딥러닝 Ch05
밑바닥부터시작하는딥러닝 Ch05밑바닥부터시작하는딥러닝 Ch05
밑바닥부터시작하는딥러닝 Ch05HyeonSeok Choi
 

What's hot (8)

Numerical Method
Numerical MethodNumerical Method
Numerical Method
 
그래프의 최단 경로 찾기
그래프의 최단 경로 찾기그래프의 최단 경로 찾기
그래프의 최단 경로 찾기
 
Graph
GraphGraph
Graph
 
DP Optimization
DP OptimizationDP Optimization
DP Optimization
 
The Art of Computer Programming 2.3.2 Tree
The Art of Computer Programming 2.3.2 TreeThe Art of Computer Programming 2.3.2 Tree
The Art of Computer Programming 2.3.2 Tree
 
분할정복
분할정복분할정복
분할정복
 
CS294-112 Lecture 06
CS294-112 Lecture 06CS294-112 Lecture 06
CS294-112 Lecture 06
 
밑바닥부터시작하는딥러닝 Ch05
밑바닥부터시작하는딥러닝 Ch05밑바닥부터시작하는딥러닝 Ch05
밑바닥부터시작하는딥러닝 Ch05
 

More from Moonki Choi

2021 여름방학 정기 세미나 3주차
2021 여름방학 정기 세미나 3주차2021 여름방학 정기 세미나 3주차
2021 여름방학 정기 세미나 3주차Moonki Choi
 
2021 여름방학 정기 세미나 1주차
2021 여름방학 정기 세미나 1주차2021 여름방학 정기 세미나 1주차
2021 여름방학 정기 세미나 1주차Moonki Choi
 
2021 알림 오세요
2021 알림 오세요2021 알림 오세요
2021 알림 오세요Moonki Choi
 
2021 1학기 정기 세미나 3주차
2021 1학기 정기 세미나 3주차2021 1학기 정기 세미나 3주차
2021 1학기 정기 세미나 3주차Moonki Choi
 
2021 1학기 정기 세미나 2주차
2021 1학기 정기 세미나 2주차2021 1학기 정기 세미나 2주차
2021 1학기 정기 세미나 2주차Moonki Choi
 
2020 겨울방학 정기스터디 3주차
2020 겨울방학 정기스터디 3주차2020 겨울방학 정기스터디 3주차
2020 겨울방학 정기스터디 3주차Moonki Choi
 
2020 겨울방학 정기스터디 2주차
2020 겨울방학 정기스터디 2주차2020 겨울방학 정기스터디 2주차
2020 겨울방학 정기스터디 2주차Moonki Choi
 
2020 2학기 정기스터디 8주차
2020 2학기 정기스터디 8주차2020 2학기 정기스터디 8주차
2020 2학기 정기스터디 8주차Moonki Choi
 
2020 2학기 정기스터디 1주차
2020 2학기 정기스터디 1주차2020 2학기 정기스터디 1주차
2020 2학기 정기스터디 1주차Moonki Choi
 
2020 1학기 정기스터디 2주차
2020 1학기 정기스터디 2주차2020 1학기 정기스터디 2주차
2020 1학기 정기스터디 2주차Moonki Choi
 
2020 1학기 정기스터디 1주차
2020 1학기 정기스터디 1주차2020 1학기 정기스터디 1주차
2020 1학기 정기스터디 1주차Moonki Choi
 

More from Moonki Choi (11)

2021 여름방학 정기 세미나 3주차
2021 여름방학 정기 세미나 3주차2021 여름방학 정기 세미나 3주차
2021 여름방학 정기 세미나 3주차
 
2021 여름방학 정기 세미나 1주차
2021 여름방학 정기 세미나 1주차2021 여름방학 정기 세미나 1주차
2021 여름방학 정기 세미나 1주차
 
2021 알림 오세요
2021 알림 오세요2021 알림 오세요
2021 알림 오세요
 
2021 1학기 정기 세미나 3주차
2021 1학기 정기 세미나 3주차2021 1학기 정기 세미나 3주차
2021 1학기 정기 세미나 3주차
 
2021 1학기 정기 세미나 2주차
2021 1학기 정기 세미나 2주차2021 1학기 정기 세미나 2주차
2021 1학기 정기 세미나 2주차
 
2020 겨울방학 정기스터디 3주차
2020 겨울방학 정기스터디 3주차2020 겨울방학 정기스터디 3주차
2020 겨울방학 정기스터디 3주차
 
2020 겨울방학 정기스터디 2주차
2020 겨울방학 정기스터디 2주차2020 겨울방학 정기스터디 2주차
2020 겨울방학 정기스터디 2주차
 
2020 2학기 정기스터디 8주차
2020 2학기 정기스터디 8주차2020 2학기 정기스터디 8주차
2020 2학기 정기스터디 8주차
 
2020 2학기 정기스터디 1주차
2020 2학기 정기스터디 1주차2020 2학기 정기스터디 1주차
2020 2학기 정기스터디 1주차
 
2020 1학기 정기스터디 2주차
2020 1학기 정기스터디 2주차2020 1학기 정기스터디 2주차
2020 1학기 정기스터디 2주차
 
2020 1학기 정기스터디 1주차
2020 1학기 정기스터디 1주차2020 1학기 정기스터디 1주차
2020 1학기 정기스터디 1주차
 

Recently uploaded

JMP를 활용한 가속열화 분석 사례
JMP를 활용한 가속열화 분석 사례JMP를 활용한 가속열화 분석 사례
JMP를 활용한 가속열화 분석 사례JMP Korea
 
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석JMP Korea
 
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?Jay Park
 
JMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
JMP를 활용한 전자/반도체 산업 Yield Enhancement MethodologyJMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
JMP를 활용한 전자/반도체 산업 Yield Enhancement MethodologyJMP Korea
 
JMP가 걸어온 여정, 새로운 도약 JMP 18!
JMP가 걸어온 여정, 새로운 도약 JMP 18!JMP가 걸어온 여정, 새로운 도약 JMP 18!
JMP가 걸어온 여정, 새로운 도약 JMP 18!JMP Korea
 
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개JMP Korea
 
공학 관점에서 바라본 JMP 머신러닝 최적화
공학 관점에서 바라본 JMP 머신러닝 최적화공학 관점에서 바라본 JMP 머신러닝 최적화
공학 관점에서 바라본 JMP 머신러닝 최적화JMP Korea
 
데이터 분석 문제 해결을 위한 나의 JMP 활용법
데이터 분석 문제 해결을 위한 나의 JMP 활용법데이터 분석 문제 해결을 위한 나의 JMP 활용법
데이터 분석 문제 해결을 위한 나의 JMP 활용법JMP Korea
 

Recently uploaded (8)

JMP를 활용한 가속열화 분석 사례
JMP를 활용한 가속열화 분석 사례JMP를 활용한 가속열화 분석 사례
JMP를 활용한 가속열화 분석 사례
 
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
실험 설계의 평가 방법: Custom Design을 중심으로 반응인자 최적화 및 Criteria 해석
 
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
(독서광) 인간이 초대한 대형 참사 - 대형 참사가 일어날 때까지 사람들은 무엇을 하고 있었는가?
 
JMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
JMP를 활용한 전자/반도체 산업 Yield Enhancement MethodologyJMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
JMP를 활용한 전자/반도체 산업 Yield Enhancement Methodology
 
JMP가 걸어온 여정, 새로운 도약 JMP 18!
JMP가 걸어온 여정, 새로운 도약 JMP 18!JMP가 걸어온 여정, 새로운 도약 JMP 18!
JMP가 걸어온 여정, 새로운 도약 JMP 18!
 
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
JMP 기능의 확장 및 내재화의 핵심 JMP-Python 소개
 
공학 관점에서 바라본 JMP 머신러닝 최적화
공학 관점에서 바라본 JMP 머신러닝 최적화공학 관점에서 바라본 JMP 머신러닝 최적화
공학 관점에서 바라본 JMP 머신러닝 최적화
 
데이터 분석 문제 해결을 위한 나의 JMP 활용법
데이터 분석 문제 해결을 위한 나의 JMP 활용법데이터 분석 문제 해결을 위한 나의 JMP 활용법
데이터 분석 문제 해결을 위한 나의 JMP 활용법
 

2020 2학기 정기스터디 2주차

  • 1. 서울시립대 알고리즘 소모임 최소 스패닝 트리 2학기 2주차
  • 2. 강의자 소개 2020 AL林 정기 스터디 2 이름 최문기 소속 서울시립대 컴퓨터과학부(16학번) 핸들 iknoom1107(BOJ) IKnoom(Codeforces) IKnoom(AtCoder) ICPC 팀 ManManChiAnunTeam - 김정현, 최문기, 최연웅
  • 3. 공지 : ICPC 2020 AL林 정기 스터디 3 2020 한국 대학생 프로그래밍 대회 / ACM-ICPC 예선 등록 9월 7일(월) ~ 9월 24일(목)
  • 4. 2020 AL林 정기 스터디 4 최소 스패닝 트리
  • 5. 스패닝 트리 (spanning tree, 신장 트리) 2020 AL林 정기 스터디 5 정점이 V개이고 간선이 E개인 무향 연결 그래프에서 간선을 V – 1개만 남겨 트리가 되도록 만든 것 (V – 1 : 최소 개수의 간선)
  • 6. 스패닝 트리 (spanning tree, 신장 트리) 2020 AL林 정기 스터디 6
  • 7. 스패닝 트리 (spanning tree, 신장 트리) 2020 AL林 정기 스터디 7 스패닝 트리는 한가지가 아닙니다. BFS 또는 DFS로 만들어지는 트리도 스패닝 트리입니다.
  • 8. 최소 스패닝 트리 (Minimum spanning tree, 최소 신장 트리) 2020 AL林 정기 스터디 8 간선의 가중치의 합이 가장 작은 스패닝 트리 → 그래프에 있는 모든 정점을 연결하기 위한 최소 비용
  • 9. 최소 스패닝 트리 (Minimum spanning tree, 최소 신장 트리) 2020 AL林 정기 스터디 9 최소 스패닝 트리를 찾는 알고리즘 ✓ 프림 알고리즘 ✓ 크루스칼 알고리즘 둘 다 그리디 알고리즘입니다.
  • 10. 최소 스패닝 트리 (Minimum spanning tree, 최소 신장 트리) 2020 AL林 정기 스터디 10 간선이 하나도 없는 상태에서 시작해서 가중치가 작은 간선을 하나씩 추가해 가는 그리디 알고리즘 프림 : 간선이 없는 상태 → 하나의 트리 → 하나의 스패닝 트리 크루스칼 : 간선이 없는 상태 → 여러개의 트리 → 하나의 스패닝 트리 두 알고리즘 모두 같은 방법으로 정당성을 증명합니다.
  • 11. 2020 AL林 정기 스터디 11 프림 알고리즘
  • 12. 프림 알고리즘(Prim's algorithm) 2020 AL林 정기 스터디 12 간선이 하나도 없는 상태에서 시작해서 가중치가 작은 간선을 하나씩 추가해 가는 그리디 알고리즘 - 하나의 정점 집합(트리)에서 점점 확장하는 방법 - 집합(트리)에 정점을 하나 더할 때마다 간선이 하나씩 확정된다. - 모든 정점을 포함할 때까지 반복한다.
  • 13. 프림 알고리즘(Prim's algorithm) 2020 AL林 정기 스터디 13 https://en.wikipedia.org/wiki/Prim%27s_algorithm#/media/File:PrimAlgDemo.gif
  • 14. 프림 알고리즘(Prim's algorithm) 2020 AL林 정기 스터디 14 어떻게 구현할까요? 다익스트라 알고리즘과 유사하게 구현합니다.
  • 15. 다익스트라 알고리즘 : O(V2) 2020 AL林 정기 스터디 15 더 구체적으로 봅시다. s : 시작점, weight[][] : 가중치 인접 행렬 distance = [∞, ∞, ..., ∞] found = [False, False, ..., False] distance[s] = 0 found[s] = True for (s에 인접한 정점 u에 대해서) { distance[u] = weight[s][u] }
  • 16. 다익스트라 알고리즘 : O(V2) 2020 AL林 정기 스터디 16 더 구체적으로 봅시다. for (V – 1번 반복) { u = (found[u]가 False이면서 distance가 가장 작은 정점) found[u] = True for (u에 인접한 정점 v에 대해서) { if (distance[v] > distance[u] + weight[u][v]) distance[v] = distance[u] + weight[u][v]) } } return distance
  • 17. 프림 알고리즘(Prim's algorithm) : O(V2) 2020 AL林 정기 스터디 17 while (모든 정점을 포함할 때까지) { 새로운 정점을 포함시키는 가장 가중치가 작은 간선을 선택한다. }
  • 18. 프림 알고리즘(Prim's algorithm) : O(V2) 2020 AL林 정기 스터디 18 s : 시작점, weight[][] : 가중치 인접 행렬 minWeight = [∞, ∞, ..., ∞] found = [False, False, ..., False] minWeight[s] = 0
  • 19. 프림 알고리즘(Prim's algorithm) : O(V2) 2020 AL林 정기 스터디 19 for (V – 1번 반복) { u = (found[u]가 False이면서 minWeight가 가장 작은 정점) found[u] = True for (u에 인접한 정점 v에 대해서) { if (minWeight[v] > weight[u][v]) minWeight[v] = weight[u][v] } }
  • 20. 프림 알고리즘(Prim's algorithm) : O(ElogV) 2020 AL林 정기 스터디 20 s : 시작점, weight[][] : 가중치 인접 리스트, priority_queue : 최소 힙 minWeight = [∞, ∞, ..., ∞] found = [False, False, ..., False] minWeight[s] = 0 priority_queue ← {0, s} // {가중치, 정점 번호}
  • 21. 프림 알고리즘(Prim's algorithm) : O(ElogV) 2020 AL林 정기 스터디 21 while (priority_queue is not empty) { u = priority_queue.pop() // 가중치가 가장 작은 간선 if (found[u] = True) continue; found[u] = True for (u에 인접한 정점 v에 대해서) { w ← (u, v)의 가중치 if (minWeight[v] > w){ minWeight[v] = w priority_queue.push( {minWeight[v], v} ) } } }
  • 22. 프림 알고리즘(Prim's algorithm) : O(ElogV) 2020 AL林 정기 스터디 22 def Prim(s): found = [False] * V min_weight = [INF] * V sum_weight = 0 min_weight[s] = 0 hq = [(0, s)] while len(hq) > 0: weight, u = heapq.heappop(hq) if found[u]: continue found[u] = True sum_weight += weight for v, w in adj[u]: if min_weight[v] > w: min_weight[v] = w heapq.heappush(hq, (min_weight[v], v)) return sum_weight 소스코드 : http://boj.kr/6114c880a073475e80c7da1f03150562
  • 23. 2020 AL林 정기 스터디 23 크루스칼 알고리즘
  • 24. 크루스칼 알고리즘(Kruskal's algorithm) 2020 AL林 정기 스터디 24 간선이 하나도 없는 상태에서 시작해서 가중치가 작은 간선을 하나씩 추가해 가는 그리디 알고리즘 - 여러 개의 집합(트리)에서 점점 확장하는 방법 - 집합(트리)과 집합(트리)를 합칠 때마다 간선이 하나씩 확정된다. - 하나의 집합(트리)가 될 때까지 반복한다.
  • 25. 크루스칼 알고리즘(Kruskal's algorithm) 2020 AL林 정기 스터디 25 https://en.wikipedia.org/wiki/Kruskal%27s_algorithm#/media/File:KruskalDemo.gif
  • 26. 크루스칼 알고리즘(Kruskal's algorithm) 2020 AL林 정기 스터디 26 while (모든 정점이 하나의 집합이 될 때까지) { 서로 다른 집합을 연결하는 가장 가중치가 작은 간선을 선택한다. }
  • 27. 크루스칼 알고리즘(Kruskal's algorithm) 2020 AL林 정기 스터디 27 간선을 가중치 순으로 정렬한다. while (V – 1개의 간선을 포함할 때까지) { 현재 간선 (u, v)에 대해서 if (u와 v가 다른 집합에 속하면) { 간선 (u, v)를 포함시킨다. } }
  • 28. 크루스칼 알고리즘(Kruskal's algorithm) 2020 AL林 정기 스터디 28 1 (a, b) 1 (a, c) 1 (b, c) 3 (a, d) 3 (c, d) a b d c 1 1 1 3 3
  • 29. 크루스칼 알고리즘(Kruskal's algorithm) 2020 AL林 정기 스터디 29 두 정점이 다른 집합에 속해 있는지 확인하는 방법 → 분리 집합의 처리 (Union-Find)
  • 30. 크루스칼 알고리즘(Kruskal's algorithm) 2020 AL林 정기 스터디 30 소스코드 : http://boj.kr/03ced5904c3a4d4ea16b9db00e55587e def find(a): if p[a] != a: p[a] = find(p[a]) return p[a] def union(a, b): p[find(a)] = find(b) if __name__ == "__main__": n, m = map(int, input().split()) p = [i for i in range(n)] edges = [] for _ in range(m): u, v, w = map(int, input().split()) edges.append((w, u - 1, v - 1))
  • 31. 크루스칼 알고리즘(Kruskal's algorithm) 2020 AL林 정기 스터디 31 # Kruskal's algorithm edges.sort() count = 0 MST = 0 for w, u, v in edges: if find(u) != find(v): union(u, v) MST += w count += 1 if count == n - 1: break print(MST)
  • 32. 크루스칼 알고리즘(Kruskal's algorithm) 2020 AL林 정기 스터디 32 정렬하고 나서 while문은 아무리 많아봤자 O(E)번 수행합니다. 두 정점이 같은 집합인지 확인하는데 O(log*V)입니다. 따라서 크루스칼 알고리즘의 시간복잡도는 O(ElogE) 입니다. (전체 과정 중 간선을 정렬하는 시간복잡도가 제일 큽니다.)
  • 33. 2020 AL林 정기 스터디 33 정당성
  • 34. 정당성 2020 AL林 정기 스터디 34 1. 탐욕적 선택의 안정성(최적해가 됨)을 증명 2. 매트로이드 이론의 관점에서의 증명
  • 37. 연습 문제 2020 AL林 정기 스터디 37 최소 스패닝 트리 1197 최소 스패닝 트리 1647 도시 분할 계획 2887 행성 터널
  • 38. 출처 2020 AL林 정기 스터디 38 https://en.wikipedia.org/