Pagini recente » Cod sursa (job #1046406) | Cod sursa (job #1521235) | Cod sursa (job #711460) | Cod sursa (job #2210503) | 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;
}