結果
問題 |
No.519 アイドルユニット
|
ユーザー |
![]() |
提出日時 | 2017-05-29 22:24:14 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 158 ms / 1,000 ms |
コード長 | 562 bytes |
コンパイル時間 | 123 ms |
コンパイル使用メモリ | 82,252 KB |
実行使用メモリ | 206,880 KB |
最終ジャッジ日時 | 2024-10-03 03:55:59 |
合計ジャッジ時間 | 3,330 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 34 |
ソースコード
def solve(): n = int(input()) A = [] for i in range(n): A.append(list(map(int, input().split()))) dp = [-1] * (1 << n) dp[0] = 0 for i in range(1 << n): if dp[i] < 0: continue for j in range(n): if i & (1 << j): continue for k in range(j + 1, n): if i & (1 << k): continue t = i | (1 << j) | (1 << k) dp[t] = max(dp[t], dp[i] + A[j][k]) break return dp[-1] print(solve())