結果
問題 |
No.2982 Logic Battle
|
ユーザー |
|
提出日時 | 2024-12-07 00:13:46 |
言語 | PyPy3 (7.3.15) |
結果 |
TLE
|
実行時間 | - |
コード長 | 632 bytes |
コンパイル時間 | 366 ms |
コンパイル使用メモリ | 82,432 KB |
実行使用メモリ | 83,712 KB |
最終ジャッジ日時 | 2024-12-07 00:14:42 |
合計ジャッジ時間 | 55,272 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 21 TLE * 17 |
ソースコード
n = int(input()) inf = 1 << 60 dp = [-inf] * (3 * n) dp[0] = dp[n] = dp[2 * n] = 0 for t in range(n): A = list(map(int, input().split())) ndp = [-inf] * (3 * n) for i1 in range(3): for i2 in range(3): if i1 == i2: continue for j in range(n): nj = j + A[i2] nv = dp[i1 * n + j] if nj >= n: nv += (n - t) * (nj - n + 1) nj = n - 1 nv += nj nj = max(nj - 1, 0) ndp[i2 * n + nj] = max(ndp[i2 * n + nj], nv) dp = ndp print(max(dp))