Pagini recente » Cod sursa (job #164066) | Monitorul de evaluare | Diferente pentru home intre reviziile 902 si 633 | Cod sursa (job #2010691) | Cod sursa (job #2731856)
#include <iostream>
#include <fstream>
#define Nmax 5000002
using namespace std;
int n, k;
long long suma = 0;
int v[Nmax];
int deque[Nmax];
int main()
{
ifstream f("deque.in");
ofstream g("deque.out");
f >> n >> k;
for(int i = 1; i<= n; i++) {
f >> v[i];
}
int front = 1;
int back = 0;
for(int i = 1; i<= n;i++){
while( v[i] <= v[deque[back]] && front <= back){
back--;
}
back++;
deque[back] = i;
if (deque[front] == i - k)
front++;
if (i >= k)
suma += v[deque[front]];
}
g << suma;
f.close();
g.close();
return 0;
}