結果
| 問題 |
No.1814 Uribo Road (Easy)
|
| ユーザー |
rlangevin
|
| 提出日時 | 2024-01-10 12:46:26 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 483 ms / 2,000 ms |
| コード長 | 1,379 bytes |
| コンパイル時間 | 384 ms |
| コンパイル使用メモリ | 82,404 KB |
| 実行使用メモリ | 78,672 KB |
| 最終ジャッジ日時 | 2024-09-27 20:20:23 |
| 合計ジャッジ時間 | 9,300 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 44 |
ソースコード
import sys
input = sys.stdin.readline
from math import *
inf = 10 ** 18
def dist(a, b):
return max(0, sqrt((X[a] - X[b])**2 + (Y[a] - Y[b])**2) - R[a] - R[b])
def dijkstra(G, K2):
ind = (0, 0)
N = len(G)
seen = [[0] * N for _ in range(K2)]
D = [[inf] * N for _ in range(K2)]
D[0][0] = 0
while True:
minv = inf
for s in range(K2):
for i in range(N):
if seen[s][i]:
continue
if D[s][i] < minv:
ind = (s, i)
minv = D[s][i]
if ind == (K2-1, N-1):
break
seen[ind[0]][ind[1]] = 1
s = ind[0]
for i in range(N):
if G[ind[1]][i] == inf:
continue
ns = s
if RR[G[ind[1]][i][1]] != -1:
ns = s | (1 << RR[G[ind[1]][i][1]])
if seen[ns][i]:
continue
D[ns][i] = min(D[ns][i], D[ind[0]][ind[1]] + G[ind[1]][i][0])
return D[K2-1][N-1]
N, M, K = map(int, input().split())
R = list(map(int, input().split()))
RR = [-1] * M
for i in range(K):
RR[R[i]-1] = i
G = [[inf] * N for _ in range(N)]
for i in range(M):
A, B, C = map(int, input().split())
A, B = A - 1, B - 1
G[A][B] = (C, i)
G[B][A] = (C, i)
print(dijkstra(G, 1 << K))
rlangevin