Pagini recente » Cod sursa (job #1621850) | Cod sursa (job #1632249) | Cod sursa (job #383718) | Cod sursa (job #2778224) | Cod sursa (job #724455)
Cod sursa(job #724455)
#include <cstdio>
#include <list>
#define val first
#define index second
using namespace std;
list< pair<long long,int> > q;
long long n,k,tot,x;
int main() {
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%lld %lld",&n,&k);
for(long o=1;o<=n;o++) {
scanf("%lld",&x);
while(!q.empty() && q.back().val>=x)
q.pop_back();
while(!q.empty() && q.front().index<=o-k)
q.pop_front();
q.push_back( make_pair(x,o) );
if(k<=o)
tot+=q.front().val;
}
printf("%lld\n",tot);
return 0;
}