結果
問題 | No.989 N×Mマス計算(K以上) |
ユーザー | le_panda_noir |
提出日時 | 2020-02-20 11:56:08 |
言語 | Elixir (1.18.1) |
結果 |
TLE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 911 bytes |
コンパイル時間 | 961 ms |
コンパイル使用メモリ | 62,520 KB |
実行使用メモリ | 192,916 KB |
最終ジャッジ日時 | 2024-12-31 03:36:30 |
合計ジャッジ時間 | 25,710 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 561 ms
54,256 KB |
testcase_01 | AC | 553 ms
54,392 KB |
testcase_02 | AC | 559 ms
53,980 KB |
testcase_03 | AC | 570 ms
54,240 KB |
testcase_04 | AC | 562 ms
54,372 KB |
testcase_05 | AC | 565 ms
54,632 KB |
testcase_06 | AC | 559 ms
54,996 KB |
testcase_07 | AC | 550 ms
54,504 KB |
testcase_08 | AC | 543 ms
54,520 KB |
testcase_09 | AC | 539 ms
54,688 KB |
testcase_10 | TLE | - |
testcase_11 | AC | 1,452 ms
110,844 KB |
testcase_12 | TLE | - |
testcase_13 | AC | 941 ms
105,264 KB |
testcase_14 | TLE | - |
testcase_15 | AC | 1,171 ms
192,916 KB |
testcase_16 | TLE | - |
testcase_17 | AC | 870 ms
104,764 KB |
testcase_18 | AC | 1,760 ms
74,548 KB |
testcase_19 | AC | 1,437 ms
117,424 KB |
ソースコード
defmodule Main do def lower_bound(list, val, l \\ -1, r \\ -1) do if r == -1 do lower_bound(list, val, l, map_size(list)) else m = div(l + r, 2) if (r - l) <= 1 do r else cond do list[m] < val -> lower_bound(list, val, m, r) list[m] >= val -> lower_bound(list, val, l, m) end end end end def main do toi = &String.to_integer/1 split = &String.split/1 [n, _m, k] = IO.gets("") |> split.() |> Enum.map(toi) [op | b] = IO.gets("") |> split.() b = Enum.map(b, toi) |> Enum.sort |> Enum.with_index |> Enum.reduce(%{}, fn({x, index}, acc) -> Map.put(acc, index, x) end) Enum.map(1..n, fn _ -> a = IO.gets("") |> String.trim |> toi.() if op == "+", do: map_size(b) - lower_bound(b, k-a), else: map_size(b) - lower_bound(b, Float.ceil(k/a)) end) |> Enum.sum |> IO.puts end end