Pagini recente » Cod sursa (job #1882865) | Cod sursa (job #2249388) | Cod sursa (job #2549219) | Cod sursa (job #553137) | Cod sursa (job #1959839)
#include <bits/stdc++.h>
using namespace std;
ifstream in("deque.in");ofstream out("deque.out");
int main() { int n,k,v[500001],dq[500001]; int sm=0;
in>>n>>k;
for(int i=1;i <=n;++i) in>>v[i];
int primul=1; int ultimul=0;
for (int i=1;i <=n;++i) {
while (primul <=ultimul&&v[i]<v[dq [ultimul]]) --ultimul;
dq [++ultimul]=i;
if (dq [primul]==i-k) ++primul;
if (i>=k) sm+=v [dq[primul]]; //cout <<sm <<" "<<v[dq [primul]]<<"\n";
}
out <<sm;
return 0;
}