컴공생의 다이어리
[파이썬, Python] 백준 6497번 : 전력난 본문
백준 6497번 : 전력난
내 코드
import sys
input = sys.stdin.readline
def find_parent(parent, x):
if parent[x] != x:
parent[x] = find_parent(parent, parent[x])
return parent[x]
def union(parent, a, b):
a = find_parent(parent, a)
b = find_parent(parent, b)
if a < b:
parent[b] = a
else:
parent[a] = b
while True:
m, n = map(int, input().split()) # m: 집의 수, n: 길의 수
if m == 0 and n == 0:
break
parent = [i for i in range(m)]
edges = [tuple(map(int, input().split())) for _ in range(n)] # 길 정보
edges.sort(key=lambda x: x[2]) # 길의 미터수를 기준으로 오름차순 정렬
result = 0
for x, y, z in edges:
if find_parent(parent, x) != find_parent(parent, y): # 이어지지 않은 길이라면
union(parent, x, y)
else: # 절약할 수 있는 길이라면
result += z
print(result)
728x90
반응형
'Development > Algorithm & Coding Test' 카테고리의 다른 글
[프로그래머스] 위장 - 자바스크립트(JS) (0) | 2022.08.29 |
---|---|
[프로그래머스] 두 큐 합 같게 만들기 - 파이썬(Python) (7) | 2022.08.28 |
[파이썬, Python] 백준 1972번 : 놀라운 문자열 (1) | 2022.08.25 |
[파이썬, Python] 백준 1043번 : 거짓말 (1) | 2022.08.24 |
[파이썬, Python] 백준 4386번 : 별자리 만들기 (0) | 2022.08.23 |
Comments