Pagini recente » Cod sursa (job #1633155) | Cod sursa (job #83938) | Cod sursa (job #1571894) | Cod sursa (job #1477876) | Cod sursa (job #570960)
Cod sursa(job #570960)
#include<stdio.h>
#include<deque>
#include<algorithm>
using namespace std;
deque<long long> a;
deque<long long> p;
long n;
long long s;
long k;
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%ld", &n);
scanf("%ld", &k);
long x;
a.push_front(0);
p.push_front(0);
for(long i=1;i<=n;i++)
{
scanf("%ld", &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;
}