Pagini recente » Cod sursa (job #2909321) | Cod sursa (job #1130919) | Cod sursa (job #2509469) | Cod sursa (job #2613806) | Cod sursa (job #1048635)
#include <fstream>
#define maxn 5000002
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int n,k;
int a[maxn],b[maxn];
int front,back;
long long suma;
int main()
{
f>>n>>k;
for(int i=1;i<=n;i++)
f>>a[i];
front=1;
back=0;
for(int i=1;i<=n;i++)
{
while(front<=back && a[i]<=a[b[back]])
back--;
b[++back]=i;
if(b[front]==i-k)
front++;
if(i>=k)
suma+=a[b[front]];
}
g<<suma;
f.close();
g.close();
return 0;
}