Submission #1314054

#TimeUsernameProblemLanguageResultExecution timeMemory
1314054husseinjuandaBoxes with souvenirs (IOI15_boxes)C++20
100 / 100
387 ms274376 KiB
#include "boxes.h"
#include <bits/stdc++.h>
using namespace std;

long long delivery(int n, int k, int l, int p[]) {
    vector<long long> j(n+1);
    for(int i = 1; i <= n; i++){
        j[i] = p[i-1];
    }
    vector<long long> pref(n+1);
    long long ans = 1e18;
    for(int i = 1; i <= n; i++){
        if(i <= k){
            pref[i] = j[i] + min(j[i], l - j[i]);
        }else{
            pref[i] = pref[i-k] + j[i] + min(j[i], l - j[i]);
        }
    }
    vector<long long> suf(n+2);
    for(int i = n; i >= 1; i--){
        if(i > n-k){
            suf[i] = (l - j[i]) + min(j[i], l - j[i]);
        }else{
            suf[i] = suf[i+k] + (l - j[i]) + min(j[i], l - j[i]);
        }
    }
    for(int i = 0; i <= n; i++){
        // cout << pref[i] << " " << suf[i+1] << " " << i << endl;
        ans = min(pref[i] + suf[i+1], ans);
    }
    return ans;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...