Pagini recente » Cod sursa (job #28075) | Cod sursa (job #853633) | Cod sursa (job #42052) | Cod sursa (job #1460175) | Cod sursa (job #2233709)
#include <fstream>
std::ifstream cin("deque.in");
std::ofstream cout("deque.out");
#define maxn 5000002
int v[maxn], dequ[maxn], N,K;
int main()
{
long long int SUM=0;
int Front=1,Back=0;
cin>>N>>K;
for(int i=1;i<=N;i++){
cin>>v[i];
}
for(int i=1;i<=N;i++){
while(Front<=Back&&v[i]<=v[dequ[Back]]){
Back--;
}
dequ[++Back]=i;
if(i-K==dequ[Front]){
Front++;
}
if(i>=K){
SUM+=v[dequ[Front]];
}
}
cout<<SUM;
}