💡문제접근
- 최단 거리를 출력하는 것이 아니라 최단 거리를 출력하는 경우 경유해야하는 집하장의 번호를 출력
💡코드(메모리 : 32276KB, 시간 : 1628ms)
import sys
input = sys.stdin.readline
INF = int(1e9)
n, m = map(int, input().strip().split())
graph = [[INF] * (n+1) for _ in range(n+1)]
result = [[0] * (n+1) for _ in range(n+1)]
for _ in range(m):
a, b, c = map(int, input().strip().split())
graph[a][b] = c
graph[b][a] = c
result[a][b] = b
result[b][a] = a
for a in range(1, n+1):
for b in range(1, n+1):
if a == b:
graph[a][b] = 0
for k in range(1, n+1):
for a in range(1, n+1):
for b in range(1, n+1):
if graph[a][b] > graph[a][k] + graph[k][b]:
graph[a][b] = graph[a][k] + graph[k][b]
result[a][b] = result[a][k]
for a in range(1, n+1):
for b in range(1, n+1):
if a == b:
result[a][b] = "-"
print(result[a][b], end = " ")
else:
print(result[a][b], end = " ")
print()
💡소요시간 : 47m