알고리즘 문제(SOL)
[백준/1922/파이썬] 네트워크 연결
Mapin
2022. 4. 1. 16:32
https://www.acmicpc.net/problem/1922
Problem
- 도현이는 컴퓨터와 컴퓨터를 모두 연결하는 네트워크를 구축하려 한다. 하지만 아쉽게도 허브가 있지 않아 컴퓨터와 컴퓨터를 직접 연결하여야 한다. 그런데 모두가 자료를 공유하기 위해서는 모든 컴퓨터가 연결이 되어 있어야 한다.
- 그런데 이왕이면 컴퓨터를 연결하는 비용을 최소로 하여야 컴퓨터를 연결하는 비용 외에 다른 곳에 돈을 더 쓸 수 있을 것이다. 이제 각 컴퓨터를 연결하는데 필요한 비용이 주어졌을 때 모든 컴퓨터를 연결하는데 필요한 최소비용을 출력하라. 모든 컴퓨터를 연결할 수 없는 경우는 없다.
조건
- a와 b가 연결이 되어 있다는 말은 a에서 b로의 경로가 존재한다는 것을 의미한다. a에서 b를 연결하는 선이 있고, b와 c를 연결하는 선이 있으면 a와 c는 연결이 되어 있다.
- 첫째 줄에 컴퓨터의 수 N (1 ≤ N ≤ 1000)가 주어진다.
- 둘째 줄에는 연결할 수 있는 선의 수 M (1 ≤ M ≤ 100,000)가 주어진다.
- 셋째 줄부터 M+2번째 줄까지 총 M개의 줄에 각 컴퓨터를 연결하는데 드는 비용이 주어진다. 이 비용의 정보는 세 개의 정수로 주어지는데, 만약에 a b c 가 주어져 있다고 하면 a컴퓨터와 b컴퓨터를 연결하는데 비용이 c (1 ≤ c ≤ 10,000) 만큼 든다는 것을 의미한다. a와 b는 같을 수도 있다.
SOL
이것도 "모든" 노드를 연결할 수 있는 "최소"비용이므로, Kruskal 알고리즘, 즉 MST를 구하는 문제이다.
#
import sys
input= sys.stdin.readline
V=int(input().rstrip())
E=int(input().rstrip())
parent=[x for x in range(V+1)]
graph=[]
def find(target):
if target==parent[target]:
return target
parent[target] = find(parent[target])
return parent[target]
def union(a,b):
a=find(a)
b=find(b)
if a <b:
parent[b] =a
else:
parent[a] =b
for _ in range(E):
a,b,c=map(int,input().split())
graph.append((a,b,c))
graph.sort(key=lambda x:x[2])
tree_edge=0
mst_cost=0
while True:
if tree_edge==V-1:
break
u,v,cost= graph.pop(0)
if find(u) != find(v):
union(u,v)
tree_edge+=1
mst_cost+=cost
print(mst_cost)