結果

問題 No.4 おもりと天秤
コンテスト
ユーザー nakamura sosuke
提出日時 2019-07-18 18:59:09
言語 Ruby
(4.0.2)
コンパイル:
ruby -w -c _filename_
実行:
ruby _filename_
結果
AC  
実行時間 83 ms / 5,000 ms
コード長 393 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 136 ms
コンパイル使用メモリ 9,216 KB
実行使用メモリ 25,344 KB
最終ジャッジ日時 2026-05-31 15:37:37
合計ジャッジ時間 2,708 ms
ジャッジサーバーID
(参考情報)
judge3_1 / judge2_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 23
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #
raw source code

N = gets.to_i
W = gets.split.map(&:to_i).sort!

def f(n, ws)
  sum = 0; ws.each{ |w| sum += w }
  #puts "  sum=#{sum}->#{sum/2}"
  return false if sum.odd?

  dp = {}
  dp[0] = true

  ws.each do | w |
    dpc = dp.clone
    dpc.keys.each do | d |
      dp[d+w] = dpc[d]
    end
  end
  #dp.sort.each{|k,v| puts "k=#{k}, v=#{v}"}
  return dp[sum/2]
end
puts f(N, W) ? 'possible' : 'impossible'
0