[백준] 1922번, 네트워크 연결 (Python)

2021. 8. 18. 16:06·알고리즘/백준
728x90
반응형

문제

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

 

1922번: 네트워크 연결

이 경우에 1-3, 2-3, 3-4, 4-5, 4-6을 연결하면 주어진 output이 나오게 된다.

www.acmicpc.net

 

코드

import heapq
n = int(input())
m = int(input())

graph = [[] for _ in range(n+1)]
visited = [False for _ in range(n+1)]
answer = 0

for i in range(m):
    a,b,c = map(int,input().split())
    graph[a].append((c,b))
    graph[b].append((c,a))

queue = []
heapq.heappush(queue, (0,1))

def Prim():
    global answer
    while queue:
        wei, now = heapq.heappop(queue)
        if visited[now] == False:
            visited[now] = True
            answer += wei
            for next_wei, next_node in graph[now]:
                heapq.heappush(queue, (next_wei, next_node))
    return answer

print(Prim())

 

모든 정점을 연결하는 가장 작은 최소비용을 구해야한다. 모든 정점을 연결하는 최소 연결 횟수는 n-1개 이고 n-1개의 간선으로 연결되어 있으면 트리형태를 가지고있어 스패닝트리 문제이다.

 

스패닝트리에 크루스칼과 프림이 있는데 프림으로 문제를 풀어보았다.

 

Prim은 다익스트라 코드와 유사하다고 생각하는데 차이점은 다익스트라는 한 정점에서 최소비용이 드는 순서대로 모두 방문하는데

 

Prim은 한 정점에서 연결된 부분중 가장 작은 비용이 드는 한가지 정점으로만 이동한다. 

 

방문체크를 해줘서 n-1만큼 이동한후 종료된다.

반응형
저작자표시 (새창열림)

'알고리즘 > 백준' 카테고리의 다른 글

[백준] 18428번, 감시 피하기 (Python)  (0) 2021.08.20
[백준] 1916번, 최소비용 구하기 (Python)  (0) 2021.08.18
[백준] 14888번, 연산자 끼워넣기 (Python)  (0) 2021.08.17
[백준] 16236번, 아기상어 (Python)  (0) 2021.08.16
[백준] 1759번, 암호 만들기 (Python)  (0) 2021.08.13
'알고리즘/백준' 카테고리의 다른 글
  • [백준] 18428번, 감시 피하기 (Python)
  • [백준] 1916번, 최소비용 구하기 (Python)
  • [백준] 14888번, 연산자 끼워넣기 (Python)
  • [백준] 16236번, 아기상어 (Python)
wookcode
wookcode
공부한 내용들을 정리하고 기록하는 블로그입니다.
    반응형
  • wookcode
    wookcode
    wookcode
  • 전체
    오늘
    어제
    • 카테고리 (196)
      • study (1)
        • 아파치 카프카 애플리케이션 프로그래밍 with 자.. (0)
        • 인프런 (1)
      • Live Study (15)
      • Programming (14)
        • Java (8)
        • Python (1)
        • Springboot (5)
        • MSA (0)
      • 알고리즘 (117)
        • 백준 (58)
        • 프로그래머스 (59)
      • 에러로그 (5)
      • 항해99 (23)
      • 면접 (1)
      • 프로젝트 (1)
      • CS (19)
        • 네트워크 (2)
        • 운영체제 (2)
        • 데이터베이스 (2)
        • 컴퓨터구조 (1)
        • Java (8)
        • Spring (4)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    spring
    SFlash
    java
    실전프로젝트
    정리
    그리디
    후기
    해결
    SpringBoot
    회고
    항해99
    에러
    미니프로젝트
    코딩테스트
    백준
    스파르타코딩클럽
    jpa
    조합
    브루트포스
    카카오코딩테스트
    알고리즘
    괄호
    인프런
    파이썬
    버그
    김영한
    항해마켓
    카카오인턴
    프로그래머스
    orm
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
wookcode
[백준] 1922번, 네트워크 연결 (Python)
상단으로

티스토리툴바