結果
| 問題 |
No.1283 Extra Fee
|
| コンテスト | |
| ユーザー |
brthyyjp
|
| 提出日時 | 2020-11-06 22:22:44 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,419 bytes |
| コンパイル時間 | 200 ms |
| コンパイル使用メモリ | 82,048 KB |
| 実行使用メモリ | 76,848 KB |
| 最終ジャッジ日時 | 2024-07-22 13:06:52 |
| 合計ジャッジ時間 | 5,342 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 11 TLE * 1 -- * 18 |
ソースコード
import sys
import io, os
input = io.BytesIO(os.read(0,os.fstat(0).st_size)).readline
n, m = map(int, input().split())
HWC = []
A = [[0]*n for _ in range(n)]
for i in range(m):
h, w, c = map(int, input().split())
h, w =h-1, w-1
HWC.append((h, w, c))
A[h][w] = c
import heapq
INF = 10**18
def dijkstra_heap(s, edge):
n = len(edge)
d = [INF] * n
used = [True] * n #True: not used
d[s] = 0
used[s] = False
edgelist = []
for e in edge[s]:
heapq.heappush(edgelist,e)
while len(edgelist):
minedge = heapq.heappop(edgelist)
if not used[minedge[1]]:
continue
v = minedge[1]
d[v] = minedge[0]
used[v] = False
for e in edge[v]:
if used[e[1]]:
heapq.heappush(edgelist,(e[0]+d[v],e[1]))
return d
ans = INF
for p in range(m):
B = [[0]*n for _ in range(n)]
for i in range(n):
for j in range(n):
B[i][j] = A[i][j]
h, w, _ = HWC[p]
B[h][w] = 0
g = [[] for _ in range(n**2)]
for i in range(n):
for j in range(n):
v = i*n+j
for di, dj in (1, 0), (0, 1):
ni, nj = i+di, j+dj
if 0 <= ni < n and 0 <= nj < n:
c = B[ni][nj]+1
u = ni*n+nj
g[v].append((c, u))
d = dijkstra_heap(0, g)
ans = min(ans, d[-1])
print(ans)
brthyyjp