結果
| 問題 | No.2695 Warp Zone | 
| コンテスト | |
| ユーザー |  sasa8uyauya | 
| 提出日時 | 2024-03-23 04:36:18 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 218 ms / 2,000 ms | 
| コード長 | 532 bytes | 
| コンパイル時間 | 289 ms | 
| コンパイル使用メモリ | 82,308 KB | 
| 実行使用メモリ | 109,056 KB | 
| 最終ジャッジ日時 | 2024-09-30 13:03:20 | 
| 合計ジャッジ時間 | 4,257 ms | 
| ジャッジサーバーID (参考情報) | judge1 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 24 | 
ソースコード
h,w,n=map(int,input().split()) o=[tuple(map(int,input().split())) for i in range(n)] e=[[] for i in range(n+2)] for i in range(n): a,b,c,d=o[i] e[n]+=[(i,abs(a-1)+abs(b-1))] e[i]+=[(n+1,1+abs(h-c)+abs(w-d))] for j in range(n): if i!=j: a2,b2,c2,d2=o[j] e[i]+=[(j,1+abs(c-a2)+abs(d-b2))] v=[h+w-2]*(n+2) v[n]=0 q=[] from heapq import heappush,heappop heappush(q,(0,n)) while len(q)>0: sc,sp=heappop(q) if sc>v[sp]: continue for tp,tc in e[sp]: if v[tp]>sc+tc: v[tp]=sc+tc heappush(q,(v[tp],tp)) print(v[n+1])
