Pagini recente » Cod sursa (job #2716190) | Cod sursa (job #1838594) | Cod sursa (job #134642) | Cod sursa (job #2160171) | Cod sursa (job #2202552)
#include <iostream>
#include <fstream>
#include <deque>
#define NMAX 5000001
using namespace std;
ifstream in("deque.in");
ofstream out("deque.out");
deque <int> deck;
int v[NMAX],n,lg,lgcurent;
long long S;
int main()
{
in>>n>>lg;
for(int i=1;i<=n;i++)
in>>v[i];
deck.push_back(1);
for(int i=2;i<=n;i++)
{
while(!deck.empty() && v[i]<=v[deck.back()])
deck.pop_back();
deck.push_back(i);
lgcurent=i-deck.front();
if(lgcurent>=lg) deck.pop_front();
if(i>=lg)
S=S+v[deck.front()];
}
out<<S;
return 0;
}