結果
問題 |
No.507 ゲーム大会(チーム決め)
|
ユーザー |
👑 |
提出日時 | 2020-04-19 20:12:30 |
言語 | Lua (LuaJit 2.1.1734355927) |
結果 |
AC
|
実行時間 | 107 ms / 3,000 ms |
コード長 | 843 bytes |
コンパイル時間 | 74 ms |
コンパイル使用メモリ | 6,944 KB |
実行使用メモリ | 19,200 KB |
最終ジャッジ日時 | 2024-10-06 05:32:01 |
合計ジャッジ時間 | 1,677 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 19 |
ソースコード
local mfl, mce = math.floor, math.ceil local mmi, mma = math.min, math.max local bls, brs = bit.lshift, bit.rshift local n, m = io.read("*n", "*n") local a = io.read("*n") local t = {} n = n - 1 for i = 1, n do t[i] = io.read("*n") end table.sort(t) local function judge(x) local tgt = a + t[x] local z = {} for i = n, 1, -1 do if i ~= x then table.insert(z, i) end if 2 * m <= #z then break end end for i = 1, m do if t[z[i]] + t[z[2 * m + 1 - i]] <= tgt then return true end end return false end if m * 2 == n + 1 then print(t[1]) elseif not judge(n) then print(-1) elseif judge(1) then print(t[1]) else local min, max = 1, n while 1 < max - min do local mid = brs(min + max, 1) if judge(mid) then max = mid else min = mid end end print(t[max]) end