#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), sum(n+1,0); for(int i=0;i> a[i]; sum[i+1]=sum[i]+a[i]; } vector > > dqp(k+1), dqm(k+1); dqp[0].push_back({0, a[0]}); dqm[0].push_back({0, -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 + abs(sum[i+1] - sum[dqm[j].front().first])); if(!dqm[j].empty()) chmax(dp[i+1][j+1], dqm[j].front().second + abs(sum[i+1] - sum[dqm[j].front().first])); if (j + 1 < k) { while (!dqp[j + 1].empty() && dqp[j + 1].back().second <= dp[i + 1][j + 1]) dqp[j + 1].pop_back(); while (!dqm[j + 1].empty() && dqm[j + 1].back().second <= dp[i + 1][j + 1]) dqm[j + 1].pop_back(); dqp[j + 1].emplace_back(i, dp[i + 1][j + 1]); dqm[j + 1].emplace_back(i, dp[i + 1][j + 1]); } } } cout << dp[n][k] << endl; return 0; }