結果

問題 No.519 アイドルユニット
ユーザー TANIGUCHI KousukeTANIGUCHI Kousuke
提出日時 2017-08-08 13:18:23
言語 Ruby
(3.3.0)
結果
TLE  
実行時間 -
コード長 569 bytes
コンパイル時間 82 ms
コンパイル使用メモリ 7,424 KB
実行使用メモリ 153,984 KB
最終ジャッジ日時 2024-04-20 05:10:04
合計ジャッジ時間 4,500 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 TLE -
testcase_01 -- -
testcase_02 -- -
testcase_03 -- -
testcase_04 -- -
testcase_05 -- -
testcase_06 -- -
testcase_07 -- -
testcase_08 -- -
testcase_09 -- -
testcase_10 -- -
testcase_11 -- -
testcase_12 -- -
testcase_13 -- -
testcase_14 -- -
testcase_15 -- -
testcase_16 -- -
testcase_17 -- -
testcase_18 -- -
testcase_19 -- -
testcase_20 -- -
testcase_21 -- -
testcase_22 -- -
testcase_23 -- -
testcase_24 -- -
testcase_25 -- -
testcase_26 -- -
testcase_27 -- -
testcase_28 -- -
testcase_29 -- -
testcase_30 -- -
testcase_31 -- -
testcase_32 -- -
testcase_33 -- -
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

N = gets.to_i
S = (1 << N)
DP = Array.new(S,-1)

def dfs(s)
  if DP[s] < 0
    N.times do |i|
      N.times do |j|
          if i > j && (s & 1 << i) > 0 && (s & 1 << j) > 0
              ex = (1 << i) | (1 << j)
              like = dfs(s ^ ex) + dfs(ex)
              if like > DP[s]
                  DP[s] = like
              end
          end
      end
    end
  end
  return DP[s]
end


unit = N.times.map{ gets.split.map(&:to_i) }
N.times do |i|
  N.times do |j|
      if i > j
        DP[1 << i | 1 << j] = unit[i][j]
      end
  end
end
dfs(S-1)
puts DP[S-1]
0