結果

問題 No.1012 荷物収集
ユーザー siman
提出日時 2020-12-30 17:57:55
言語 Ruby
(3.4.1)
結果
TLE  
実行時間 -
コード長 393 bytes
コンパイル時間 373 ms
コンパイル使用メモリ 7,552 KB
実行使用メモリ 30,884 KB
最終ジャッジ日時 2024-10-07 19:50:26
合計ジャッジ時間 6,404 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other TLE * 1 -- * 40
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

N, Q = gets.split.map(&:to_i)
B = N.times.map { gets.split.map(&:to_i) }
X = gets.split.map(&:to_i)

def f(pos, limit)
  cost = 0

  B.each do |x, w|
    cost += w * (pos - x).abs
  end

  cost <= limit
end

X.each do |x|
  ng = 0
  ok = 10 ** 18

  while (ok - ng).abs >= 2
    limit = (ok + ng) / 2

    if f(x, limit)
      ok = limit
    else
      ng = limit
    end
  end

  puts ok
end
0