Pagini recente » Cod sursa (job #728431) | Cod sursa (job #362376) | Cod sursa (job #3187340) | Cod sursa (job #1502544) | Cod sursa (job #1717917)
#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, "%lld\n", sum);
return 0;
}