Pagini recente » Cod sursa (job #1663977) | Cod sursa (job #152820) | Cod sursa (job #2880751) | Cod sursa (job #1653249) | Cod sursa (job #2720545)
#include <fstream>
#include <deque>
#define ll long long
std::ifstream fin("deque.in");
std::ofstream fout("deque.out");
std::deque<std::pair<int, int>>dq;
int main() {
ll n, c, k, s = 0;
fin>>n>>k;
for(int i=0;i<n;i++) {
fin>>c;
if(i<k-1) {
dq.push_back({c, i});
continue;
}
while(!dq.empty() and dq.front().second<=i-k) dq.pop_front();
while(!dq.empty() and dq.back().first>=c) dq.pop_back();
dq.push_back({c, i});
s+=dq.front().first;
}
fout<<s;
}