Pagini recente » Cod sursa (job #2599041) | Cod sursa (job #589100) | Cod sursa (job #2909545) | Cod sursa (job #3033423) | Cod sursa (job #2374715)
#include <iostream>
#include <deque>
using namespace std;
deque<int> DQ, currItems;
int n, k, x;
long long total;
void rez()
{
scanf("%d %d", &n, &k);
for(int i = 0; i<k; i++)
{
scanf("%d", &x);
currItems.push_front(x);
while(!DQ.empty() && DQ.front() > x)
{
DQ.pop_front();
}
DQ.push_front(x);
}
total+=DQ.back();
for(int i = k; i<n; i++)
{
if(DQ.back() == currItems.back())
DQ.pop_back();
currItems.pop_back();
scanf("%d", &x);
currItems.push_front(x);
while(!DQ.empty() && DQ.front() > x)
{
DQ.pop_front();
}
DQ.push_front(x);
total+=DQ.back();
}
printf("%lld", total);
}
int main()
{
freopen("deque.in", "r", stdin);
freopen("deque.out", "w", stdout);
rez();
return 0;
}