Pagini recente » Cod sursa (job #2829982) | Cod sursa (job #3190834) | Cod sursa (job #3209139) | Cod sursa (job #2755486) | Cod sursa (job #1717916)
#include <fstream>
#include <cstdio>
#include <deque>
using namespace std;
struct punct
{
int val;
int poz;
};
int main()
{
//fstream in("deque.in");
//ofstream out("deque.out");
FILE *in = fopen ("deque.in", "r");
FILE *out = fopen("deque.out", "w");
deque<punct> coada;
long long sum = 0;
int n, k; //in >> n >> k;
fscanf(in, "%d", &n);
fscanf(in, "%d", &k);
for (int i = 1; i <= n; i++)
{
//int x; in >> x;
int x;
fscanf(in, "%d", &x);
punct p; p.poz = i; p.val = x;
while (!coada.empty() && p.val <= coada.back().val) coada.pop_back();
coada.push_back(p);
if (coada.front().poz == i - k) coada.pop_front();
if (i >= k)
sum += coada.front().val;
}
//out << sum;
fprintf(out, "%d\n", sum);
return 0;
}