Pagini recente » Cod sursa (job #2346185) | Cod sursa (job #3156996) | Cod sursa (job #916122) | Cod sursa (job #58062) | Cod sursa (job #1861319)
#include <cstdio>
#include <queue>
using namespace std;
struct myint
{
int x,y;
};
deque<myint> q;
int v[5000010];
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
int i,n,k;
long long int max;
myint a;
scanf("%d %d",&n,&k);
for(i=1; i<=n; ++i)
scanf("%d",&v[i]);
max=0;
for(i=1; i<=n; ++i)
{
while(!q.empty() && q.back().x>=v[i])
q.pop_back();
a.x=v[i];
a.y=i;
q.push_back(a);
if(q.front().y==i-k)
q.pop_front();
if(i>=k)
max=max+q.front().x;
}
printf("%d",max);
return 0;
}