|
| 1 | +INF = int(1e9) # 무한을 의미하는 값으로 10억을 설정합니다. |
| 2 | + |
1 | 3 | # 노드의 개수 및 간선의 개수를 입력 받습니다. |
2 | 4 | n, m = map(int, input().split()) |
3 | | -# 2차원 리스트를 만들고, 모든 값을 무한으로 초기화합니다. |
4 | | -adj = [[1e9] * (n + 1) for _ in range(n + 1)] |
| 5 | +# 2차원 리스트(그래프 표현)를 만들고, 모든 값을 무한으로 초기화합니다. |
| 6 | +graph = [[INF] * (n + 1) for _ in range(n + 1)] |
5 | 7 |
|
6 | 8 | # 자기 자신에서 자기 자신으로 가는 비용은 0으로 초기화합니다. |
7 | 9 | for a in range(1, n + 1): |
8 | 10 | for b in range(1, n + 1): |
9 | 11 | if a == b: |
10 | | - adj[a][b] = 0 |
| 12 | + graph[a][b] = 0 |
11 | 13 |
|
12 | 14 | # 각 간선에 대한 정보를 입력 받아, 그 값으로 초기화합니다. |
13 | 15 | for _ in range(m): |
14 | 16 | # A와 B가 서로에게 가는 비용은 1이라고 설정합니다. |
15 | 17 | a, b = map(int, input().split()) |
16 | | - adj[a][b] = 1 |
17 | | - adj[b][a] = 1 |
| 18 | + graph[a][b] = 1 |
| 19 | + graph[b][a] = 1 |
18 | 20 |
|
19 | 21 | # 거쳐 갈 노드 x와 최종 목적지 노드 k를 입력 받습니다. |
20 | 22 | x, k = map(int, input().split()) |
21 | 23 |
|
22 | | -# 플로이드 워셜 알고리즘을 정의합니다. |
23 | | -def solve(): |
24 | | - for k in range(1, n + 1): |
25 | | - for a in range(1, n + 1): |
26 | | - for b in range(1, n + 1): |
27 | | - adj[a][b] = min(adj[a][b], adj[a][k] + adj[k][b]) |
28 | | - |
29 | | -# 플로이드 워셜 알고리즘을 수행합니다. |
30 | | -solve() |
| 24 | +# 점화식에 따라 플로이드 워셜 알고리즘을 수행합니다. |
| 25 | +for k in range(1, n + 1): |
| 26 | + for a in range(1, n + 1): |
| 27 | + for b in range(1, n + 1): |
| 28 | + graph[a][b] = min(graph[a][b], graph[a][k] + graph[k][b]) |
31 | 29 |
|
32 | 30 | # 수행된 결과를 출력합니다. |
33 | | -distance = adj[1][k] + adj[k][x] |
| 31 | +distance = graph[1][k] + graph[k][x] |
| 32 | + |
| 33 | +# 도달할 수 없는 경우, -1을 출력합니다. |
34 | 34 | if distance >= 1e9: |
35 | 35 | print("-1") |
| 36 | +# 도달할 수 있다면, 최단 거리를 출력합니다. |
36 | 37 | else: |
37 | 38 | print(distance) |
0 commit comments