Pagini recente » Cod sursa (job #671205) | Borderou de evaluare (job #1089968) | Cod sursa (job #741905) | Cod sursa (job #806220) | Cod sursa (job #3256666)
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
deque <int> a;
int n,k,v[5000001];
long long s;
int main()
{
fin>>n>>k;
for(int i=1; i<=n; i++)
{
fin>>v[i];
}
for(int i=1; i<=n; i++)
{
if(!a.empty() && a.front()<i-k+1){
a.pop_front();
}
while( !a.empty() && v[a.back()]>=v[i]){
a.pop_back();
}
a.push_back(i);
if(i>=k){
s+=v[a.front()];
}
}
fout<<s;
return 0;
}