結果
問題 |
No.1 道のショートカット
|
ユーザー |
![]() |
提出日時 | 2016-08-23 01:00:13 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
WA
|
実行時間 | - |
コード長 | 825 bytes |
コンパイル時間 | 99 ms |
コンパイル使用メモリ | 12,544 KB |
実行使用メモリ | 29,312 KB |
最終ジャッジ日時 | 2024-07-08 04:30:13 |
合計ジャッジ時間 | 15,244 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 WA * 1 |
other | AC * 11 WA * 12 TLE * 1 -- * 16 |
ソースコード
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(N): if connect[d[2]][i]: heapq.heappush(q,(d[0] + time[d[2]][i],d[1] + cost[d[2]][i],i)) return -1 if ret == 10 ** 9 + 7 else ret print(dijkstra(0,N - 1))