結果
| 問題 |
No.1283 Extra Fee
|
| コンテスト | |
| ユーザー |
brthyyjp
|
| 提出日時 | 2020-11-06 22:31:10 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,423 bytes |
| コンパイル時間 | 369 ms |
| コンパイル使用メモリ | 82,176 KB |
| 実行使用メモリ | 197,452 KB |
| 最終ジャッジ日時 | 2024-07-22 13:16:12 |
| 合計ジャッジ時間 | 11,819 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 15 WA * 15 |
ソースコード
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
g = [[] for _ in range(n**2)]
rg = [[] 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 = A[ni][nj]+1
u = ni*n+nj
g[v].append((c, u))
rg[u].append((c, v))
d = dijkstra_heap(0, g)
#print(d)
cur = n**2-1
X = []
while cur != 0:
for c, u in rg[cur]:
if d[u]+c == d[cur]:
cur = u
X.append(c-1)
#print(X)
ans = d[-1]-max(X)
print(ans)
brthyyjp