Cod sursa(job #1845743)
| Utilizator | Data | 11 ianuarie 2017 20:56:39 | |
|---|---|---|---|
| Problema | Deque | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.62 kb |
#include <cstdio>
#include <deque>
FILE* in;
FILE* out;
struct elem{
int val;
int tin;
};
std::deque<elem> a;
int main()
{
in=fopen("deque.in","r");
out=fopen("deque.out","w");
int n,k,x;
fscanf(in,"%d%d",&n,&k);
long long rez=0;
for(int i=1; i<=n; i++)
{
fscanf(in,"%d",&x);
while(!a.empty() && x < a.back().val )
a.pop_back();
a.push_back(elem{x,i});
if(i>=k)
{
rez+=a.front().val;
if(a.front().tin==i-k+1)
a.pop_front();
}
}
fprintf(out,"%lld",rez);
return 0;
}