Pagini recente » Cod sursa (job #472119) | Cod sursa (job #1272903) | Cod sursa (job #1816750) | Cod sursa (job #815205) | Cod sursa (job #570962)
Cod sursa(job #570962)
#include<stdio.h>
#include<deque>
#include<algorithm>
using namespace std;
deque<int> a;
deque<int> p;
int n;
long long s;
int k;
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%d", &n);
scanf("%d", &k);
int x;
a.push_front(0);
p.push_front(0);
for(int i=1;i<=n;i++)
{
scanf("%d", &x);
while(x <= a.back() && !a.empty())
{
a.pop_back();
p.pop_back();
}
a.push_back(x);
p.push_back(i);
if(p.front() <= i-k)
{
a.pop_front();
p.pop_front();
}
if(i>=k)
s=s+a.front();
}
printf("%lld ", s);
return 0;
}