Mai intai trebuie sa te autentifici.
Cod sursa(job #2163591)
Utilizator | Data | 12 martie 2018 19:04:48 | |
---|---|---|---|
Problema | Deque | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.64 kb |
#include <stdio.h>
#include <iostream>
#include <deque>
using namespace std;
FILE *f,*g;
int v[5000009];
deque <int> q;
int main()
{
int n,k,i,j,x,y;
long long ss=0;
f=fopen("deque.in","r");
g=fopen("deque.out","w");
fscanf(f,"%d %d",&n,&k);
for(i=1;i<=n;++i)
fscanf(f,"%d",&v[i]);
for(i=1;i<=n;++i)
{
while(!q.empty() && v[i]<=v[q.back()])
q.pop_back();
q.push_back(i);
if(q.front()==i-k)
q.pop_front();
if(i>=k)
ss+=v[q.front()];
}
fprintf(g,"%lld",ss);
fclose(f);
fclose(g);
return 0;
}