結果
問題 |
No.2739 Time is money
|
ユーザー |
|
提出日時 | 2024-05-29 09:27:19 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 698 bytes |
コンパイル時間 | 332 ms |
コンパイル使用メモリ | 82,064 KB |
実行使用メモリ | 159,296 KB |
最終ジャッジ日時 | 2024-12-20 20:59:19 |
合計ジャッジ時間 | 21,511 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 14 WA * 4 |
ソースコード
from heapq import heapify, heappop, heappush N, M, X = map(int, input().split()) G = [[] for _ in range(N)] for _ in range(M): u, v, C, T = map(int, input().split()) u -= 1; v -= 1 G[u].append((v, C, T)) G[v].append((u, C, T)) H = [(0, 0, 0)] heapify(H) vis = [False] * N vis[0] = True Time = [10 ** 9] * N Time[0] = 0 Cost = [0] * N while len(H) > 0: T, u, C = heappop(H) for v, C1, T1 in G[u]: if vis[v]: continue if Time[v] > Time[u] + T1: Time[v] = Time[u] + T1 Cost[v] = Cost[u] + C1 heappush(H, (Time[v], v, Cost[v])) if Time[N - 1] == 10 ** 9: print(-1) else: print(Time[N - 1] + (Cost[N - 1] + X - 1) // X)