Pagini recente » Cod sursa (job #2966104) | Cod sursa (job #1965473) | Cod sursa (job #2527578) | Cod sursa (job #635758) | Cod sursa (job #546312)
Cod sursa(job #546312)
/*
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 citire()
{
scanf("%i%i",&n,&k);
for (int i = 1; i <= n; ++i)
scanf("%i",&v[i]);
}
void rezolvare_deque()
{
long long s=0;
for (int i = 1; i <= n; ++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("%i",s);
}
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
citire();
rezolvare_deque();
return 0;
}