結果
問題 | No.614 壊れたキャンパス |
ユーザー | mkawa2 |
提出日時 | 2020-06-04 22:13:18 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,441 ms / 2,000 ms |
コード長 | 1,372 bytes |
コンパイル時間 | 320 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 262,292 KB |
最終ジャッジ日時 | 2024-11-30 08:19:09 |
合計ジャッジ時間 | 16,640 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 39 ms
52,864 KB |
testcase_01 | AC | 40 ms
52,480 KB |
testcase_02 | AC | 39 ms
52,992 KB |
testcase_03 | AC | 39 ms
52,480 KB |
testcase_04 | AC | 39 ms
52,864 KB |
testcase_05 | AC | 39 ms
52,480 KB |
testcase_06 | AC | 40 ms
52,608 KB |
testcase_07 | AC | 39 ms
52,736 KB |
testcase_08 | AC | 1,305 ms
234,100 KB |
testcase_09 | AC | 1,350 ms
245,688 KB |
testcase_10 | AC | 1,096 ms
227,032 KB |
testcase_11 | AC | 1,416 ms
245,256 KB |
testcase_12 | AC | 1,441 ms
256,128 KB |
testcase_13 | AC | 1,435 ms
244,128 KB |
testcase_14 | AC | 1,293 ms
247,472 KB |
testcase_15 | AC | 1,048 ms
232,704 KB |
testcase_16 | AC | 1,302 ms
230,072 KB |
testcase_17 | AC | 832 ms
262,292 KB |
testcase_18 | AC | 864 ms
229,124 KB |
testcase_19 | AC | 488 ms
201,648 KB |
ソースコード
from heapq import *import sysdef MI(): return map(int, sys.stdin.readline().split())def main():n, m, k, s, t = MI()abc = []floor = [set() for _ in range(n)]floor[0].add(s)floor[n - 1].add(t)for _ in range(m):a, b, c = MI()floor[a - 1].add(b)floor[a].add(c)abc.append((a-1, b, c))iftou = {}u = 0for i in range(n):for f in floor[i]:iftou[i, f] = uu += 1un = us = iftou[0, s]t = iftou[n - 1, t]to = [[] for _ in range(un)]for a, b, c in abc:u = iftou[a, b]v = iftou[a + 1, c]to[u].append((v, 0))for i in range(n):v = -1pf = -1for f in sorted(floor[i]):if v == -1:v = iftou[i, f]pf = fcontinueu = iftou[i, f]cost = f - pfto[u].append((v, cost))to[v].append((u, cost))v = upf = fhp = []heappush(hp, (0, s))dist = [-1] * unwhile hp:d, u = heappop(hp)if u == t:print(d)exit()if dist[u] != -1: continuedist[u] = dfor v, cost in to[u]:if dist[v] != -1: continueheappush(hp, (d + cost, v))print(-1)main()