반응형
import sys
input = sys.stdin.readline
n, m = map(int, input().split())
INF = int(1e9)
graph = [[INF] * (n + 1) for _ in range(n + 1)]
for _ in range(m):
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])
ans = INF
for i in range(1, n + 1):
ans = min(ans, graph[i][i])
print(-1 if ans == INF else ans)
플로이드-워셜
pypy로 제출