This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
#include<ext/numeric>
#include <ext/pb_ds/assoc_container.hpp> // Common file
#include <ext/pb_ds/tree_policy.hpp> // Including tree_order_statistics_node_update
#define Fast ios::sync_with_stdio(false),cin.tie(nullptr),cout.tie(nullptr)
using namespace std;
using namespace __gnu_cxx;
using namespace __gnu_pbds;
#define all(s) s.begin(),s.end()
#define rall(s) s.rbegin(),s.rend()
#define int long long
template<class T> using ordered_set = tree<T, null_type , less<T> ,rb_tree_tag , tree_order_statistics_node_update> ;
typedef long long ll;
const int N=3e5+3,LG=__lg(N)+2,M=21,MOD=998244353,inf=3e14;
pair<int,int> dp[2][N];
int v[N],n;
pair<int,int> sol(int mid) {
    dp[0][0] = {0, 0};
    dp[1][0] = {v[0] - mid, 1};
    for (int i = 1; i < n; i++) {
        dp[0][i] = max(dp[0][i - 1], dp[1][i - 1]);
        dp[1][i] =
                max(make_pair(dp[0][i - 1].first + v[i] - mid,
                              dp[0][i - 1].second + 1),
                    make_pair(dp[1][i - 1].first + v[i], dp[1][i - 1].second));
    }
    return max(dp[0][n - 1], dp[1][n - 1]);
}
void solve() {
    int k;
    cin>>n>>k;
    for (int i = 0; i <n ; ++i)
        cin>>v[i];
    int l=0,r=inf;
    while(r-l>1){
        int mid=l+(r-l)/2;
        if(sol(mid).second<k)
            r=mid;
        else l=mid;
    }
    cout<<sol(l).first+l*k<<'\n';
}
signed main() {
    Fast;
    int tc = 1;
    //cin >> tc;
    for (int i = 1; i <= tc; ++i) {
        // cout<<"Case #"<<i<<": ";
        solve();
    }
}
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... |