Pagini recente » Cod sursa (job #1098310) | Cod sursa (job #622368) | Cod sursa (job #2455478) | Cod sursa (job #188168) | Cod sursa (job #2374770)
#include <iostream>
#include <deque>
using namespace std;
deque<int> DQ;
long long a[5000005];
int n, k;
long long total;
void rez()
{
scanf("%d %d", &n, &k);
for(int i = 1; i<=n; i++)
{
scanf("%lld", &a[i]);
while(!DQ.empty() && a[DQ.front()] > a[i])
{
DQ.pop_front();
}
DQ.push_front(i);
if(DQ.back() == i-k)
DQ.pop_back();
if(i>=k)
total+=a[DQ.back()];
}
printf("%lld", total);
}
int main()
{
freopen("deque.in", "r", stdin);
freopen("deque.out", "w", stdout);
rez();
return 0;
}