Pagini recente » Cod sursa (job #1616867) | Cod sursa (job #1207894) | Cod sursa (job #2452789) | Cod sursa (job #708372) | Cod sursa (job #928175)
Cod sursa(job #928175)
#include<fstream>
#define N 5000001
using namespace std;
ifstream in("deque.in");
ofstream out("deque.out");
int i,n,k,v[N],dq[N],st=1,dr;
long long s;
void stanga(int i){
if(i-dq[st]==k) st++;
}
void dreapta(int i){
while(st<=dr && v[i]<=v[dq[dr]])
dr--;
}
int main(){
in>>n>>k;
for(i=1;i<=n;i++) in>>v[i];
for(i=1;i<=n;i++){
if(i>k) stanga(i);
dreapta(i);
dq[++dr]=i;
if(i>=k) s+=v[dq[st]];
}
out<<s;
return 0;
}