#include #define be(v) (v).begin(),(v).end() #define pb(q) push_back(q) typedef long long ll; using namespace std; const ll mod=1000000007, INF=(1LL<<60); #define doublecout(a) cout<> n >> k >> m; vector a(n+1,0); for(int i=0;i> a[i]; } for(int i = n - 1;i>=0;i--){ a[i] += a[i+1]; } vector > > dqp(k+1), dqm(k+1); dqp[0].push_back({-1, a[0]}); dqm[0].push_back({-1, -a[0]}); vector > dp(n+1, vector (k+1, 0)); for(int i=0;i=0;j--){ while(!dqp[j].empty() && dqp[j].front().first < i-m) dqp[j].pop_front(); while(!dqm[j].empty() && dqm[j].front().first < i-m) dqm[j].pop_front(); if(!dqp[j].empty()) chmax(dp[i+1][j+1], dqp[j].front().second - a[i + 1]); if(!dqm[j].empty()) chmax(dp[i+1][j+1], dqm[j].front().second + a[i + 1]); if (j + 1 < k) { while (!dqp[j + 1].empty() && dqp[j + 1].back().second <= dp[i + 1][j + 1] + a[i + 1]) dqp[j + 1].pop_back(); while (!dqm[j + 1].empty() && dqm[j + 1].back().second <= dp[i + 1][j + 1] - a[i + 1]) dqm[j + 1].pop_back(); dqp[j + 1].emplace_back(i, dp[i + 1][j + 1] + a[i + 1]); dqm[j + 1].emplace_back(i, dp[i + 1][j + 1] - a[i + 1]); } } } cout << dp[n][k] << endl; return 0; }