728x90
https://www.acmicpc.net/problem/1197
1197번: 최소 스패닝 트리
첫째 줄에 정점의 개수 V(1 ≤ V ≤ 10,000)와 간선의 개수 E(1 ≤ E ≤ 100,000)가 주어진다. 다음 E개의 줄에는 각 간선에 대한 정보를 나타내는 세 정수 A, B, C가 주어진다. 이는 A번 정점과 B번 정점이
www.acmicpc.net
💡 문제 풀이
최소 신장 트리 문제이다. 크루스칼로 해결했다.
가장 기본적인 문제로 알고리즘의 개념만 잘 숙지하고 있다면 해결할 수 있다.
✔️ 느낀 점
다음에는 크루스칼 외에 프림 알고리즘으로도 풀어봐야겠다.
💻 코드
import sys
input = sys.stdin.readline
V, E = map(int, input().split())
edges= []
for _ in range(E):
edges.append(list(map(int, input().split())))
edges.sort(key=lambda x:x[2])
parent = list(range(V+1))
def find(x):
if x != parent[x]:
parent[x] = find(parent[x])
return parent[x]
def union(x,y):
x = find(x)
y = find(y)
parent[y] = x
cnt, ans = 0, 0
while True:
if cnt == V-1: break
edge = edges.pop(0) # start, end, cost
if find(edge[0]) != find(edge[1]):
union(edge[0], edge[1])
ans += edge[2]
cnt += 1
print(ans)
'문제 풀이 > 백준(BOJ)' 카테고리의 다른 글
[Python] 백준 14572번 : 스터디 그룹 (0) | 2022.09.07 |
---|---|
[Python] 백준 1774번 : 우주신과의 교감 (0) | 2022.09.04 |
[Python] 백준 2458번 : 키 순서 (0) | 2022.09.02 |
[Python] 백준 1043번 : 거짓말 (빅뱅 거짓말 아님ㅋ) (0) | 2022.09.01 |
[Python] 백준 18223번 : 민준이와 마산 그리고 건우 (0) | 2022.08.29 |
댓글