Pagini recente » Cod sursa (job #2397537) | Cod sursa (job #1104253) | Cod sursa (job #534675) | Cod sursa (job #540106) | Cod sursa (job #2938164)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
long long minim(deque<int> d){
long long mini=1LL*d.back();
d.pop_back();
while(!d.empty()){
if(d.back()<mini)
mini=1LL*d.back();
d.pop_back();
}
return mini;
}
int main()
{
long long n,k,s=0,a[5000001];
deque<int> d;
fin>>n>>k;
for(int i=1;i<=n;i++){
fin>>a[i];
while(!d.empty() && a[d.back()]>a[i])
d.pop_back();
while(!d.empty() && d.front()==i-k)
d.pop_front();
d.push_back(i);
if(i>=k)
s+=a[d.front()];
}
fout<<s;
return 0;
}