Pagini recente » Cod sursa (job #470102) | Cod sursa (job #3143799) | Cod sursa (job #2946402) | Cod sursa (job #2084216) | Cod sursa (job #3162551)
#include <fstream>
#include <algorithm>
#include <climits>
using namespace std;
ifstream fin ("deque.in");
ofstream fout("deque.out");
int v[5000001];
int dq[5000001];
int n,i,k;
long long sum;
int main()
{
fin>>n>>k;
int st=0,dr=0;
v[0]=INT_MIN;
for(i=1;i<=n;i++){
fin>>v[i];
while(i-dq[st]+1>k) ///elimin de la inceput deoarece lungimea secvntei ce se termina in i este mai mare decat k
st++;
while(st<=dr && v[i]<=v[dq[dr]])
dr--;
dq[++dr]=i;
if(i>=k)
sum=sum+v[dq[st]];
}
fout<<sum;
return 0;
}