For Programmer
9.(2) 최단경로 알고리즘 (플로이다 워셜 알고리즘) 본문
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
'코팅테스트 > 코딩테스트 이론 정리' 카테고리의 다른 글
10.(1) 서로소 집합 자료구조(union-find) - 기타 그래프 이론 (0) | 2021.08.24 |
---|---|
9.(3) 최단경로 알고리즘 문제 (0) | 2021.08.24 |
9.(1) 최단 경로 알고리즘(다익스트라 알고리즘) (0) | 2021.08.21 |
8-2. DP(다이나믹동적계획법) 문제2 (0) | 2021.08.20 |
8-2. DP(다이나믹동적계획법) 문제 (0) | 2021.08.19 |