結果
問題 | No.1375 Divide and Update |
ユーザー |
|
提出日時 | 2021-02-05 22:01:49 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 144 ms / 2,000 ms |
コード長 | 555 bytes |
コンパイル時間 | 171 ms |
コンパイル使用メモリ | 82,340 KB |
実行使用メモリ | 114,816 KB |
最終ジャッジ日時 | 2024-07-02 12:31:02 |
合計ジャッジ時間 | 3,997 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 19 |
ソースコード
N, X, Y = map(int, input().split()) A = list(map(int, input().split())) dpX = [0] * N dpX[0] = X - A[0] for i in range(1, N): dpX[i] = max(dpX[i - 1], 0) + X - A[i] maxX = [dpX[0]] * N for i in range(1, N): maxX[i] = max(maxX[i - 1], dpX[i]) A = A[::-1] dpY = [0] * N dpY[0] = Y - A[0] for i in range(1, N): dpY[i] = max(dpY[i - 1], 0) + Y - A[i] maxY = [dpY[0]] * N for i in range(1, N): maxY[i] = max(maxY[i - 1], dpY[i]) A = A[::-1] sumA = sum(A) maxY = maxY[::-1] for i in range(1, N - 1): print(sumA + maxX[i - 1] + maxY[i + 1])