Pagini recente » Cod sursa (job #2750204) | Cod sursa (job #3185477) | Cod sursa (job #1555120) | Cod sursa (job #2632688) | Cod sursa (job #1556213)
#include <cstdio>
#include <deque>
using namespace std;
deque <int> minim;
int v[5000010];
int main()
{
int i,n,k,sm = 0;
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%d%d",&n,&k);
for(i=1;i<=n;i++)
scanf("%d",&v[i]);
for(i=1;i<=n;i++)
{
while(!minim.empty() && v[i] <= v[minim.back()]) minim.pop_back();
minim.push_back(i);
if(minim.front() == i - k) minim.pop_front();
if(i >= k) sm += v[minim.front()];
}
printf("%d",sm);
}