Pagini recente » Cod sursa (job #2666380) | Cod sursa (job #778400) | Cod sursa (job #2903297) | Istoria paginii runda/de_vacanta | Cod sursa (job #546327)
Cod sursa(job #546327)
/*
Elem noi sterg din coada de la sfarsit cele mai mari ca ea.
(sunt preferate elem minime de indice mai mare)
*/
#include <cstdio>
#include <deque>
using namespace std;
const int N = 5000001;
deque<int> coada;
int v[N];
int n,k;
void rezolvare_deque()
{
long long s=0;
scanf("%d%d",&n,&k);
for (int i = 1; i <= n; ++i)
{
scanf("%d",&v[i]);
while (!coada.empty() && v[i] <= v[coada.back()])
coada.pop_back();
coada.push_back(i);
if (coada.front() == i-k)
coada.pop_front();
if (i >= k)
s += v[coada.front()];
}
printf("%lld",s);
}
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
rezolvare_deque();
return 0;
}