For Programmer

9.(2) 최단경로 알고리즘 (플로이다 워셜 알고리즘) 본문

코팅테스트/코딩테스트 이론 정리

9.(2) 최단경로 알고리즘 (플로이다 워셜 알고리즘)

유지광이 2021. 8. 24. 12:14
728x90

소스코드

INF = (1e9) #무한을 의미하는 값으로 10억 설정

#노드의 개수 및 간선의 개수를 입력 받기
n = int(input())
m = int(input())
#2차원 리스트를 만들고, 무한으로 초기화
graph = [[INF]*(10) for _ in range(10)]

#자기 자신에서 자기 자신으로 가는 비용은 0으로 초기화
for a in range(1,10):
    for b in range(1,10):
        if a == b:
            graph[a][b] = 0

#각 간선에 대한 정보를 입력 받아, 그 값으로 초기화
for _ in range(m):
    #A에서 B로 가는 비용은 C라고 설정
    a,b,c = map(int,input().split())
    graph[a][b] = c

#점화식에 따라 플로이드 워셜 알고리즘 수행
for k in range(1,n+1):
    for a in range(1,n+1):
        for b in range(1,n+1):
            graph[a][b] = min(graph[a][b],graph[a][k]+graph[k][b])

#수행된 결과를 출력
for a in range(1,n+1):
    for b in range(1,n+1):
        #도달할 수 없는 경우, 무한 이라고 출력
        if graph[a][b] == INF:
            print("INFINITY",end=" ")
        #도달할 수 있는 경우 거리를 출력
        else:
            print(graph[a][b], end=" ")
    print()
728x90
Comments