結果
問題 | No.2100 [Cherry Alpha C] Two-way Steps |
ユーザー |
👑 |
提出日時 | 2022-10-23 21:04:05 |
言語 | Lua (LuaJit 2.1.1734355927) |
結果 |
AC
|
実行時間 | 259 ms / 2,000 ms |
コード長 | 1,144 bytes |
コンパイル時間 | 466 ms |
コンパイル使用メモリ | 6,684 KB |
実行使用メモリ | 38,512 KB |
最終ジャッジ日時 | 2024-07-02 11:10:45 |
合計ジャッジ時間 | 9,864 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 48 |
ソースコード
local mmi, mma = math.min, math.max local n, m = io.read("*n", "*n") local h = {} local edge = {} local invedge = {} for i = 1, n do h[i] = io.read("*n") edge[i] = {} invedge[i] = {} end for i = 1, m do local x, y = io.read("*n", "*n") table.insert(edge[x], y) table.insert(invedge[y], x) end local function solve() local upped = {0} local downed = {0} for i = 2, n do upped[i], downed[i] = -1, -1 end for i = 1, n - 1 do for j = 1, #edge[i] do local dst = edge[i][j] if h[i] < h[dst] and 0 <= downed[i] then upped[dst] = mma(upped[dst], downed[i] + h[dst] - h[i]) end if h[dst] < h[i] and 0 <= upped[i] then downed[dst] = mma(downed[dst], upped[i]) end if h[dst] < h[i] and 0 <= downed[i] then downed[dst] = mma(downed[dst], downed[i]) end end end print(mma(downed[n], upped[n])) end solve() for i = 1, n do edge[i] = {} local z = n + 1 - i if i < z then h[i], h[z] = h[z], h[i] end end for i = 1, n do for j = 1, #invedge[i] do local dst = invedge[i][j] table.insert(edge[n + 1 - i], n + 1 - dst) end end solve()