Pagini recente » Cod sursa (job #1574589) | Cod sursa (job #488869) | Cod sursa (job #3141545) | Ciorna | Cod sursa (job #1576544)
#include<stdio.h>
#include<deque>
using namespace std;
deque <int> d;
deque <int> poz;
int main(){
FILE*fin=fopen("deque.in", "r");
FILE*fout=fopen("deque.out", "w");
int n, k, i, a, s;
fscanf(fin, "%d%d", &n, &k);
s=0;
for(i=1; i<=n; i++){
if(d.empty()==0 && i-poz.front()>=k){
d.pop_front();
poz.pop_front();
}
fscanf(fin, "%d", &a);
while(!d.empty() && a<=d.back()){
d.pop_back();
poz.pop_back();
}
d.push_back(a);
poz.push_back(i);
if(i>=k)
s+=d.front();
// printf("%d %d\n", i, s);
}
fprintf(fout, "%d", s);
fclose(fin);
fclose(fout);
return 0;
}