Pagini recente » Cod sursa (job #2201282) | Cod sursa (job #2942089) | Cod sursa (job #1763403) | Cod sursa (job #1779939) | Cod sursa (job #1316868)
#include <iostream>
#include <fstream>
using namespace std;
long long n,k,que[5000001],a[5000001],i,sum,first,last;
int main()
{
ifstream f("deque.in");
ofstream g("deque.out");
f>>n>>k;
for (i=1;i<=n;i++)
f>>a[i];
first=1;
last=0;
for (i=1;i<=n;i++)
{
while ((first <= last) && (a[i]<= a[ que [last] ])) last--;
que [++last]=i;
if (que[first]==i-k) first++;
if (i>=k) sum+=a[que[first]];
}
g<<sum;
return 0;
}