[백준 11403] 경로 찾기 ❗

코뉴·2022년 1월 19일
0

백준🍳

목록 보기
69/149
post-custom-banner

https://www.acmicpc.net/problem/11403

🥚문제


🥚입력/출력


🍳코드

import sys
input = sys.stdin.readline

n = int(input().strip())
g = [list(map(int, input().split())) for _ in range(n)]

# Floyd Warshall
# i -> k번 노드 -> j 로 거쳐가는 경로를 확인한다
for k in range(n):
    for i in range(n):
        for j in range(n):
            if g[i][j] == 1 or (g[i][k] == 1 and g[k][j] == 1):
                g[i][j] = 1
                """
                어차피 g[i][j] = 1로 갱신하기 때문에
                사실 g[i][j] == 1인 경우는 검사 안하고 넘어가도 됨
                그러나 이해를 위해 if문에서 검사하기로!
                """

# 출력
for row in g:
    for x in row:
        print(x, end=' ')
    print()

🧂아이디어

Floyd-Warshall 알고리즘

  • i번 노드 -> k번 노드 -> j번 노드로 거쳐가는 경로를 확인
  • 위 문제에서, 경로가 존재하는 경우는 (i, j)가 직접 연결되어 있는 경우와, k를 거쳐서 연결되는 경우 (i, k) -> (k, j)
  • 경로가 존재하는 경우에는 값을 1로 갱신해준다
profile
코뉴의 도딩기록
post-custom-banner

0개의 댓글