Pagini recente » Cod sursa (job #839284) | Cod sursa (job #1897979) | Cod sursa (job #138768) | Cod sursa (job #2766473) | Cod sursa (job #2579247)
#include <bits/stdc++.h>
using namespace std;
deque<int> d;
int v[5000005];
int main()
{
ifstream cin("deque.in");
ofstream cout("deque.out");
int n,i,k,a;
long long s;
cin>>n>>k;
for(i=1;i<=n;i++)
cin>>v[i];
for(i=1;i<=k;i++)
{
a=d.size();
while(a>0 && v[i]<v[d.back()]){
d.pop_back();
a=d.size();
}
d.push_back(i);
}
s=v[d.front()];
for(i=k+1;i<=n;i++){
a=d.size();
while(a>0 && d.front()<i-k+1){
d.pop_front();
a=d.size();
}
a=d.size();
while(a>0 && v[i]<v[d.back()]){
d.pop_back();
a=d.size();
}
d.push_back(i);
s+=v[d.front()];
}
cout<<s;
return 0;
}