結果
| 問題 | 
                            No.1375 Divide and Update
                             | 
                    
| コンテスト | |
| ユーザー | 
                             RheoTommy
                         | 
                    
| 提出日時 | 2021-02-05 23:25:39 | 
| 言語 | C++17  (gcc 13.3.0 + boost 1.87.0)  | 
                    
| 結果 | 
                             
                                WA
                                 
                             
                            
                         | 
                    
| 実行時間 | - | 
| コード長 | 1,398 bytes | 
| コンパイル時間 | 1,771 ms | 
| コンパイル使用メモリ | 195,716 KB | 
| 最終ジャッジ日時 | 2025-01-18 13:08:30 | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge3 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 1 WA * 1 | 
| other | AC * 3 WA * 16 | 
ソースコード
#include<bits/stdc++.h>
#define rep(i, n) for (int i = 0; i < (int) n; i++)
using ll = long long;
using namespace std;
const long long INF = 1ll << 60;
void chmax(ll &x, ll y) {
    x = max(x, y);
}
void chmin(ll &x, ll y) {
    x = min(x, y);
}
ll dp[300000][3];
ll dp2[300000][3];
int main() {
    ll n, x, y;
    cin >> n >> x >> y;
    
    vector<ll> a(n);
    rep(i, n) cin >> a[i];
    
    rep(i, n) {
        chmax(dp[i + 1][0], dp[i][0] + a[i]);
        chmax(dp[i + 1][2], dp[i][2] + a[i]);
        chmax(dp[i + 1][1], dp[i][0] + x);
        chmax(dp[i + 1][2], dp[i][0] + x);
        chmax(dp[i + 1][1], dp[i][1] + x);
        chmax(dp[i + 1][2], dp[i][1] + x);
    }
    
//    rep(i, n + 1) {
//        cout << dp[i][0] << " " << dp[i][1] << " " << dp[i][2] << endl;
//    }
    
    reverse(a.begin(), a.end());
    
    rep(i, n) {
        chmax(dp2[i + 1][0], dp2[i][0] + a[i]);
        chmax(dp2[i + 1][2], dp2[i][2] + a[i]);
        chmax(dp2[i + 1][1], dp2[i][0] + y);
        chmax(dp2[i + 1][2], dp2[i][0] + y);
        chmax(dp2[i + 1][1], dp2[i][1] + y);
        chmax(dp2[i + 1][2], dp2[i][1] + y);
    }
    
//    rep(i, n + 1) {
//        cout << dp2[i][0] << " " << dp2[i][1] << " " << dp2[i][2] << endl;
//    }
    
    reverse(a.begin(), a.end());
    
    for (ll i = 1; i < n - 1; i++) {
        cout << dp[i][2] + a[i] + dp2[n - i - 1][2] << endl;
    }
}
            
            
            
        
            
RheoTommy