백준 1197. 최소 스패닝 트리

2024. 11. 3. 14:25·백준

https://www.acmicpc.net/problem/1197

1. 프림

# 프림 풀이(다익스트라)

import heapq
import sys
input = sys.stdin.readline

N, M = map(int,input().split())
arr = [[] for _ in range(N+1)]
visited = [ 0 for _ in range(N+1)]

for _ in range(M):
    A,B,C = map(int,input().split())

    arr[A].append([C,B]) # 가중치를 기준으로 push, pop을 해줘야하니까 순서를 바꾸기
    arr[B].append([C,A])

ans = 0
cnt = 0

q = [[0,1]] # 1에서 출발할거다! 가중치 없이!

while q:

    if cnt == N: # 모든 정점을 방문했다면? = 모든 정점이 연결됐다면
        break

    weight,node = heapq.heappop(q) # 최소비용 꺼내주기

    if visited[node] == 0:
        visited[node] = 1
        ans += weight
        cnt += 1

        for nxt in arr[node]:
            heapq.heappush(q,nxt) # 담아주기

print(ans)

2. 크루스칼 풀이(최적화된 유니온파인드) -> 1보다 메모리는 더 많이 사용하지만 시간은 절반

# 크루스칼 풀이(유니온파인드)

# 1. 모든 링크를 한번에 가져온다.
# 2. 링크를 연결하면서 같은 집합으로 만들어준다.
# 3. 만약에 이미 같은 집합이라면 연결하지 않는다.

# union 최적화!

import sys
input = sys.stdin.readline

def _find(x):
    while par[x] != x:
        x = par[x]
    return x

def _union(a, b):
    a = _find(a)
    b = _find(b)

    if a == b:
        return

    if rank[a] < rank[b]:
        par[a] = b
    elif rank[b] < rank[a]:
        par[b] = a
    else:
        par[a] = b
        rank[b] += 1

N, M = map(int,input().split())
link = [list(map(int,input().split())) for _ in range(M)]
link.sort(key=lambda x:x[2]) # 가중치 기준으로 정렬

par = [i for i in range(1_000_001)]
rank = [0 for _ in range(1_000_001)]

ans = 0

for i in range(M):
    A = link[i][0]
    B = link[i][1]
    weight = link[i][2]

    A = _find(A)
    B = _find(B)

    if A == B:
        continue
    else:
        _union(A,B)
        ans += weight

print(ans)
저작자표시 (새창열림)

'백준' 카테고리의 다른 글

백준 4485. 녹색 옷 입은 애가 젤다지?  (0) 2024.11.04
백준 1865. 웜홀  (0) 2024.11.03
백준 1240. 노드사이의 거리  (0) 2024.11.03
백준 1717. 집합의 표현  (0) 2024.11.03
백준 2458. 키 순서  (0) 2024.11.02
'백준' 카테고리의 다른 글
  • 백준 4485. 녹색 옷 입은 애가 젤다지?
  • 백준 1865. 웜홀
  • 백준 1240. 노드사이의 거리
  • 백준 1717. 집합의 표현
버그잡는고양이발
버그잡는고양이발
주니어 개발자입니다!
  • 버그잡는고양이발
    지극히평범한개발블로그
    버그잡는고양이발
  • 전체
    오늘
    어제
    • 분류 전체보기 (382)
      • React (16)
      • Next.js (5)
      • Javascript (5)
      • Typescript (4)
      • Node.js (2)
      • Cs (16)
      • 트러블 슈팅 (5)
      • Html (1)
      • Css (3)
      • Django (0)
      • vue (0)
      • Java (2)
      • Python (0)
      • 독서 (1)
      • 기타 (3)
      • 백준 (192)
      • swea (31)
      • 프로그래머스 (30)
      • 이코테 (4)
      • 99클럽 코테 스터디 (30)
      • ssafy (31)
      • IT기사 (1)
  • 블로그 메뉴

    • 홈
    • 태그
  • 인기 글

  • 태그

    항해99
    개발자취업
    Til
    99클럽
    코딩테스트준비
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
버그잡는고양이발
백준 1197. 최소 스패닝 트리
상단으로

티스토리툴바