Algorithm/boj

[파이썬] 1956 운동

takeU 2022. 6. 28. 21:24
반응형
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로 제출