Pagini recente » Cod sursa (job #543892) | Cod sursa (job #651034) | Cod sursa (job #1011346) | Cod sursa (job #785041) | Cod sursa (job #570958)
Cod sursa(job #570958)
#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("%d", &n);
scanf("%d", &k);
long x;
a.push_front(0);
p.push_front(0);
for(long 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("%d ", s);
return 0;
}