Pagini recente » Cod sursa (job #2875020) | Istoria paginii utilizator/crazvan6 | Cod sursa (job #2462341) | Cod sursa (job #584457) | Cod sursa (job #2732519)
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("deque.in");
ofstream out("deque.out");
int v[5000010], aux[5000010];
int main()
{ int n,k,s=0,i,start=1, sfarsit=0;
in>>n>>k;
for(i=1; i<=n; i++){
in>>v[i];
while(start<=sfarsit && v[i]<=v[aux[sfarsit]]){
sfarsit--;
}
sfarsit++;
aux[sfarsit]=i;
if(aux[start]==i-k) start++;
if(i>=k)
s=s+v[aux[start]];
}
out<<s;
in.close();
out.close();
return 0;
}