結果
問題 |
No.845 最長の切符
|
ユーザー |
|
提出日時 | 2022-01-27 13:17:23 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,103 ms / 3,000 ms |
コード長 | 689 bytes |
コンパイル時間 | 188 ms |
コンパイル使用メモリ | 82,944 KB |
実行使用メモリ | 89,856 KB |
最終ジャッジ日時 | 2024-12-25 02:59:56 |
合計ジャッジ時間 | 6,040 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 27 |
ソースコード
N,M = map(int,input().split()) G = [[] for _ in range(N)] for _ in range(M): a,b,c = map(int,input().split()) a -= 1 b -= 1 G[a].append((b,c)) G[b].append((a,c)) inf = 10 ** 8 dp = [[0] * N for _ in range(1 << N)] for j in range(N): mask = 1 << j dp[mask][j] = 0 for bit in range(1 << N): for j in range(N): mask = 1 << j if bit & mask == 0:continue for v,c in G[j]: maskv = 1 << v if bit & maskv:continue dp[bit ^ maskv][v] = max(dp[bit ^ maskv][v],dp[bit][j] + c) _max = 0 for bit in range(1 << N): for j in range(N): if dp[bit][j] > _max: _max = dp[bit][j] print(_max)