Pagini recente » Cod sursa (job #441585) | Cod sursa (job #972993) | Cod sursa (job #1217536) | Cod sursa (job #1409485) | Cod sursa (job #2469859)
#include <cstdio>
#include <deque>
using namespace std;
FILE* in=fopen("deque.in", "r");
FILE* out=fopen("deque.out", "w");
deque<pair<int, int> > d;
int main()
{
int n, k;
fscanf(in, "%d%d", &n, &k);
int x;
fscanf(in, "%d", &x);
d.push_back(make_pair(x, 1));
int sum=0;
for(int i=2; i<=n; ++i)
{
fscanf(in, "%d", &x);
while(d.back().first>=x) d.pop_back();
d.push_back(make_pair(x, i));
while(d.front().second+k-1<i) d.pop_front();
if(i>=k) sum+=d.front().first;
}
fprintf(out, "%d", sum);
}