Pagini recente » Cod sursa (job #1866672) | Cod sursa (job #1515673) | Cod sursa (job #2978713) | Cod sursa (job #2940135) | Cod sursa (job #2264646)
#include <iostream>
#include <deque>
#include <vector>
#include <cstdio>
using namespace std;
deque <int> q;
vector <int> a;
int n,k,x;
long long sum;
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
cin>>n>>k;
for(int i=0;i<k;++i)
{
cin>>x;
a.push_back(x);
while(!q.empty() && a[q.back()]>x)
q.pop_back();
q.push_back(i);
}
sum+=a[q.front()];
for(int i=k;i<n;++i)
{
cin>>x;
a.push_back(x);
while(!q.empty() && a[q.back()]>x)
q.pop_back();
q.push_back(i);
while(!q.empty() && q.back()-q.front()>=k)
q.pop_front();
sum+=a[q.front()];
}
cout<<sum;
return 0;
}