結果

問題 No.614 壊れたキャンパス
コンテスト
ユーザー obakyan
提出日時 2019-05-06 13:57:44
言語 Lua
(LuaJit 2.1.1774638290)
コンパイル:
luajit -b _filename_ a.out
実行:
luajit _filename_
結果
TLE  
実行時間 -
コード長 880 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 101 ms
コンパイル使用メモリ 6,400 KB
実行使用メモリ 66,304 KB
最終ジャッジ日時 2026-03-15 13:40:13
合計ジャッジ時間 10,364 ms
ジャッジサーバーID
(参考情報)
judge1_0 / judge3_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 18 TLE * 2
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

local ior = io.input()
local n, m, k, s, t = ior:read("*n", "*n", "*n", "*n", "*n")
local bridge = {}
for i = 1, n - 1 do bridge[i] = {} end
for i = 1, m do
  local a, b, c = ior:read("*n", "*n", "*n")
  local tmp = {}
  tmp.b, tmp.c = b, c
  table.insert(bridge[a], tmp)
end
local mmi = math.min
local poslist = {}
poslist[s] = 0
for i = 1, n - 1 do
  local npos = {}
  for floor, cost in pairs(poslist) do
    local br = bridge[i]
    for j = 1, #br do
      local ncost = cost + math.abs(floor - br[j].b)
      if(npos[br[j].c] == nil) then
        npos[br[j].c] = ncost
      else
        npos[br[j].c] = mmi(npos[br[j].c], ncost)
      end
    end
  end
  poslist = npos
end
local lastval = -1
for floor, cost in pairs(poslist) do
  local ncost = cost + math.abs(floor - t)
  if(lastval < 0) then lastval = ncost
  else lastval = mmi(lastval, ncost)
  end
end
print(lastval)
0