結果
| 問題 |
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])