Pagini recente » Monitorul de evaluare | Cod sursa (job #884902) | Cod sursa (job #26474) | Cod sursa (job #556504) | Cod sursa (job #3343399)
#include <fstream>
#include <queue>
#define int long long
#define nmax (int)(5e6+1)
using namespace std;
ifstream cin("deque.in");
ofstream cout("deque.out");
int n,k,v[nmax],sol;
deque<int>q;
signed main()
{
cin>>n>>k;
for(int i=1;i<=n;i++){
cin>>v[i];
while(!q.empty()&&v[q.back()]>=v[i])
q.pop_back();
while(!q.empty()&&q.front()<=i-k)
q.pop_front();
q.push_back(i);
if(i>=k)
sol+=v[q.front()];
}
cout<<sol;
return 0;
}