結果
問題 | No.519 アイドルユニット |
ユーザー |
![]() |
提出日時 | 2017-05-28 22:45:55 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 486 bytes |
コンパイル時間 | 290 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 191,104 KB |
最終ジャッジ日時 | 2024-09-21 15:42:50 |
合計ジャッジ時間 | 3,249 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 8 WA * 26 |
ソースコード
N = int(input()) f = [[int(j) for j in input().split()] for i in range(N)] dp = [-1 for i in range(1 << N)] def dfs(S): if S == (1<<N)-1: return 0 if dp[S] != -1: return dp[S] ret = 0 mi1 = -1 mi2 = -1 for i in range(N): if S>>i&1: continue for j in range(i+1,N): if S>>j&1 or i == j: continue if mi1 == - 1 or mi2 == -2 or f[mi1][mi2] < f[i][j]: mi1 = i mi2 = j ret = dfs(S | 1 << mi1 | 1 << mi2) + f[mi1][mi2] dp[S] = ret return ret print(dfs(0))