結果

問題 No.17 2つの地点に泊まりたい
ユーザー noriocnorioc
提出日時 2024-10-21 02:13:05
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 71 ms / 5,000 ms
コード長 618 bytes
コンパイル時間 673 ms
コンパイル使用メモリ 82,204 KB
実行使用メモリ 74,980 KB
最終ジャッジ日時 2024-10-21 02:13:09
合計ジャッジ時間 2,963 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 36 ms
53,284 KB
testcase_01 AC 37 ms
53,132 KB
testcase_02 AC 42 ms
61,440 KB
testcase_03 AC 53 ms
65,144 KB
testcase_04 AC 46 ms
61,608 KB
testcase_05 AC 65 ms
69,812 KB
testcase_06 AC 61 ms
66,552 KB
testcase_07 AC 50 ms
64,392 KB
testcase_08 AC 71 ms
74,756 KB
testcase_09 AC 71 ms
74,980 KB
testcase_10 AC 54 ms
64,656 KB
testcase_11 AC 61 ms
67,624 KB
testcase_12 AC 38 ms
53,352 KB
testcase_13 AC 37 ms
52,068 KB
testcase_14 AC 36 ms
53,252 KB
testcase_15 AC 36 ms
53,104 KB
testcase_16 AC 36 ms
52,500 KB
testcase_17 AC 42 ms
60,608 KB
testcase_18 AC 49 ms
63,752 KB
testcase_19 AC 50 ms
63,180 KB
testcase_20 AC 43 ms
60,108 KB
testcase_21 AC 41 ms
60,596 KB
testcase_22 AC 51 ms
63,708 KB
testcase_23 AC 60 ms
67,160 KB
testcase_24 AC 69 ms
66,976 KB
testcase_25 AC 41 ms
59,412 KB
testcase_26 AC 64 ms
69,724 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

INF = 1 << 60
N = int(input())
S = [int(input()) for _ in range(N)]
M = int(input())

dp = [[INF] * N for _ in range(N)]
for i in range(N):
    dp[i][i] = 0

for _ in range(M):
    A, B, C = map(int, input().split())
    dp[A][B] = dp[B][A] = C

# ワーシャル・フロイド法
for k in range(N):
    for i in range(N):
        for j in range(N):
            dp[i][j] = min(dp[i][j], dp[i][k] + dp[k][j])

ans = INF
# 0 - i - j - N-1 (i, j に滞在)
for i in range(1, N-1):
    for j in range(1, N-1):
        if i == j: continue
        ans = min(ans, dp[0][i] + S[i] + dp[i][j] + S[j] + dp[j][N-1])

print(ans)
0