結果
問題 |
No.1 道のショートカット
|
ユーザー |
![]() |
提出日時 | 2016-08-23 01:12:22 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
TLE
|
実行時間 | - |
コード長 | 805 bytes |
コンパイル時間 | 191 ms |
コンパイル使用メモリ | 12,544 KB |
実行使用メモリ | 132,388 KB |
最終ジャッジ日時 | 2024-07-08 04:30:23 |
合計ジャッジ時間 | 8,812 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 7 TLE * 1 -- * 32 |
ソースコード
import heapq N,C,V = int(input()),int(input()),int(input()) S = [int(i) - 1 for i in input().split()] T = [int(i) - 1 for i in input().split()] Y = [int(i) for i in input().split()] M = [int(i) for i in input().split()] cost = [[0 for j in range(N)] for i in range(N)] time = [[0 for j in range(N)] for i in range(N)] connect = [[False for j in range(N)] for i in range(N)] for i in range(V): connect[S[i]][T[i]] = True cost[S[i]][T[i]] = Y[i] time[S[i]][T[i]] = M[i] def dijkstra(s,t): q = [(0,0,s)] ret = 10 ** 9 + 7 while len(q) > 0: d = heapq.heappop(q) if d[1] > C: continue if d[2] == t: ret = min(ret,d[0]) continue for i in range(V): if S[i] == d[2]: heapq.heappush(q,(d[0] + M[i],d[1] + Y[i],T[i])) return -1 if ret == 10 ** 9 + 7 else ret print(dijkstra(0,N - 1))