Pagini recente » Cod sursa (job #2539429) | Cod sursa (job #2778511) | Cod sursa (job #2612786) | Cod sursa (job #2206655) | Cod sursa (job #1671722)
#include <fstream>
#include <deque>
using namespace std;
struct nr {
int poz, val;
}num;
int n, k, i, x;
deque<nr> d;
long long s;
int main () {
ifstream fi("deque.in");
ofstream fo("deque.out");
fi >> n >> k;
for (i = 1; i <= k-1; i++)
fi >> x, num.val = x, num.poz = i, d.push_back(num);
for (i = k; i <= n; i++) {
fi >> x; num.val = x, num.poz = i;
if (d.front().poz < i-k+1)
d.pop_front();
while (d.back().val > x and !d.empty())
d.pop_back();
d.push_back(num);
s += (long long)d.front().val;
}
fo << s;
return 0;
}