結果

問題 No.3111 Toll Optimization
ユーザー sasa8uyauya
提出日時 2025-04-19 15:34:56
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 1,866 ms / 5,000 ms
コード長 658 bytes
コンパイル時間 549 ms
コンパイル使用メモリ 82,260 KB
実行使用メモリ 200,776 KB
最終ジャッジ日時 2025-04-19 15:35:43
合計ジャッジ時間 46,921 ms
ジャッジサーバーID
(参考情報)
judge2 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 70
権限があれば一括ダウンロードができます

ソースコード

diff #

n,m,k=map(int,input().split())
e=[[] for _ in range(n*(k+1))]
c=list(map(int,input().split()))
for i in range(m):
  u,v=map(int,input().split())
  u-=1
  v-=1
  for j in range(k+1):
    e[n*j+u]+=[(n*j+v,c[i])]
    e[n*j+v]+=[(n*j+u,c[i])]
    if j+1<=k:
      e[n*j+u]+=[(n*(j+1)+v,0)]
      e[n*j+v]+=[(n*(j+1)+u,0)]
for i in range(n):
  for j in range(k):
    e[n*j+i]+=[(n*(j+1)+i,0)]
X=10**20
v=[X]*n*(k+1)
v[0]=0
q=[(v[0],0)]
from heapq import heappush,heappop
while len(q):
  sc,sp=heappop(q)
  if sc>v[sp]:
    continue
  for tp,c in e[sp]:
    tc=sc+c
    if v[tp]>tc:
      v[tp]=tc
      heappush(q,(v[tp],tp))
a=v[n*k+n-1]
print(a if a<X else -1)
0