#include <iostream>
#include <vector>
#include <algorithm>
#include <cmath>
using namespace std;
long long delivery(int N, int K, int L, int v[]){
    //N is the number of teams that need their gifts
    //K is the carrying capacity
    //L is the number of nodes (ex. L = 8 gives us: 0,1,2,3,4,5,6,7)
    //v[] is an array
    vector<long long> team_pos;
    team_pos.push_back(0);
    for(int i = 0; i<N; i++){
        team_pos.push_back(v[i]);
    }
    vector<long long> cw(N+K+5, 0);
    vector<long long> ccw(N+5, 0);
    cw[0] = 0;
    ccw[0] = 0;
    sort(team_pos.begin(), team_pos.end());
    //----- ACCOUNT FOR DEFAULT FIRST
    //cw[i] = minimum total distance to DELIVER FIRST i GIFTS via CW
    //ccw[i] = minimum total distance to DELIVER FIRST i GITS via CCW
    for (int i = 1; i <= N; i++){
        long long d_cw  = 2*team_pos[i];
        long long d_ccw = 2*(L - team_pos[N - i + 1]);
        cw[i]  = min(d_cw,  (long long)L);
        ccw[i] = min(d_ccw, (long long)L);
    }
   //------ ACCOUNT FOR CAPACITY
   //cout << "ACCOUNT FOR CAPACITY\n";
   for (int i = K+1; i <= N; i++){
        //cout << i << " " << i-K << "\n";
        cw[i] += cw[i-K];
    }
    for (int i = K+1; i <= N; i++){
        //cout << N-i << " " << N-(i+K) << "\n";
        ccw[i] += ccw[i-K];
    }
    //print
   /*for(int i =0 ; i<cw.size(); i++){
        cout << "cw[" << i << "] = " << cw[i] << "\n";
   }
   cout << "\n";
   for(int i =0 ; i<cw.size(); i++){
        cout << "ccw[" << i << "] = " << ccw[i] << "\n";
   }*/
   //cout << "\n";
   long long no_full = 1e18;
   long long yes_full = 1e18;
   for(int i = 0; i<=N; i++){
        no_full = min(no_full, cw[i] + ccw[N-i]);
        //cout << i << " " << no_full << "\n";
   }
   //cout << "\n";
   for(int i = 0 ; i+K <= N; i++){
         yes_full = min(yes_full, cw[i] + L + ccw[N-(i+K)]);
         //cout << i << " " << yes_full << "\n";
   }
   //cout << no_full << " " << yes_full << "\n";
   //cout << min(no_full, yes_full) << "\n";
   return min(no_full, yes_full);
}
/*
int main(){
    int n;
    int k;
    int l;
    cin >> n >> k >> l;
    int v[n];
    for(int i = 0; i<n; i++){
        int x;
        cin >> x;
        v[i] = x;
    }
    cout << delivery(n,k,l,v) << endl;
}
*/
| # | 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... |