結果

問題 No.4 おもりと天秤
ユーザー nakamura sosuke
提出日時 2019-07-18 18:59:09
言語 Ruby
(3.4.1)
結果
AC  
実行時間 152 ms / 5,000 ms
コード長 393 bytes
コンパイル時間 706 ms
コンパイル使用メモリ 7,424 KB
実行使用メモリ 22,272 KB
最終ジャッジ日時 2024-12-25 22:36:35
合計ジャッジ時間 3,930 ms
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 23
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

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