Pagini recente » Cod sursa (job #775837) | Cod sursa (job #1857735) | Cod sursa (job #851095) | Istoria paginii runda/oji-10-2 | Cod sursa (job #628756)
Cod sursa(job #628756)
#include<stdio.h>
#include<deque>
using namespace std;
deque<int>lista_smen;
deque<int>poz;
int n,k;
int main(){
freopen("deque.in","r",stdin);
freopen("deque.out","w",stdout);
scanf("%d", &n);
scanf("%d", &k);
long long s=0;
int x;
for(int i=1;i<=n;i++){
scanf("%d", &x);
if(!lista_smen.empty()){
while(x<=lista_smen.back()){
poz.pop_back();
lista_smen.pop_back();
if(lista_smen.empty())
break;
}
}
poz.push_back(i);
lista_smen.push_back(x);
if(i-poz.front()==k){
poz.pop_front();
lista_smen.pop_front();
}
if(i>=k){
s=s+lista_smen.front();
}
}
printf("%lld", s);
return 0;
}