Pagini recente » Cod sursa (job #1780935) | Istoria paginii utilizator/valentina.varzaru | Cod sursa (job #960567) | Cod sursa (job #209415) | Cod sursa (job #1962694)
#include <cstdio>
#include <vector>
#include <deque>
using namespace std;
vector <int> A;
deque <int> Q;
int n,k;
long long sum;
void Read(){
int i,x;
freopen("deque.in","r",stdin);
scanf("%d%d",&n,&k);
A.push_back(0);
for (i=1;i<=n;++i){
scanf("%d",&x);
A.push_back(x);
}
}
void Solve(){
int i;
for (i=1;i<=n;++i){
while (!Q.empty() && A[i]<=A[Q.back()]) Q.pop_back();
Q.push_back(i);
if (Q.front()==i-k) Q.pop_front();
if (i>=k) sum+=A[Q.front()];
}
}
void Write(){
freopen("deque.out","w",stdout);
printf("%lld",sum);
}
int main()
{
Read();
Solve();
Write();
return 0;
}