結果
問題 |
No.3158 Collect Stamps
|
ユーザー |
![]() |
提出日時 | 2025-05-23 19:30:08 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 363 ms / 2,000 ms |
コード長 | 704 bytes |
コンパイル時間 | 571 ms |
コンパイル使用メモリ | 82,200 KB |
実行使用メモリ | 89,696 KB |
最終ジャッジ日時 | 2025-05-23 19:30:18 |
合計ジャッジ時間 | 6,557 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 35 |
ソースコード
N, M, K = map(int, input().split()) A = list(map(int, input().split())) T = [list(map(int, input().split())) for _ in range(N)] INF = 1<<60 dp = [[INF]*N for _ in range(1<<N)] for i in range(N): dp[1<<i][i] = 0 for bit in range(1<<N): for i in range(N): if dp[bit][i] == INF: continue for j in range(N): if not 1<<j & bit: dp[bit|1<<j][j] = min(dp[bit|1<<j][j], dp[bit][i]+T[i][j]) MIN = [INF]*N for i in range(N): for j in range(K): MIN[i] = min(MIN[i], T[i][A[j]-1]) ans = INF for bit in range(1<<N): if bit.bit_count() < M: continue for i in range(N): ans = min(ans, dp[bit][i]+MIN[i]) print(ans)