Pagini recente » Cod sursa (job #2437155) | Cod sursa (job #1912003) | Cod sursa (job #1847942) | Cod sursa (job #2733377) | Cod sursa (job #1059104)
#include <cstdio>
#include <deque>
using namespace std;
deque <int> q;
deque <int> :: iterator it;
int v[5000010],i,k,n,s;
bool ok;
int main()
{
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%d%d",&n,&k);
for (i=1;i<=n;i++)
scanf("%d",&v[i]);
i=1;
ok=true;
q.push_back(1);
for(i=2;i<=k;i++){
while(!q.empty()&&v[q.end()]>v[i]) q.pop_back();
q.push_back(i);
}
s=0;
i=k+1;
for(i=k+1;i<=n;i++)
{
s+=v[q.front()];
while(!q.empty()&&v[q.end()]>v[i]) q.pop_back();
q.push_back(i);
if (i-k==v[q.front()]) q.pop();
}
printf("\n%d",s);
return 0;
}