Pagini recente » Cod sursa (job #2253749) | Cod sursa (job #2902433) | Cod sursa (job #3179747) | Cod sursa (job #2317730) | Cod sursa (job #1556217)
#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]);
minim.push_back(1);
for(i=2;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);
}