Mai intai trebuie sa te autentifici.
Cod sursa(job #1046059)
| Utilizator | Data | 2 decembrie 2013 17:12:37 | |
|---|---|---|---|
| Problema | Deque | Scor | 0 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.63 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream f ("deque.in");
ofstream g ("deque.out");
#define MaxN 5000010
int main()
{
int n,k,i;
int a[MaxN], Dque[MaxN];
int Front, Back;
long long sum=0;
f>>n>>k;
for(i=0;i<n;i++)
f>>a[i];
Front=1;Back=1;
Dque[Back]=0;
for (i=1;i<n;i++)
{
while (Front<=Back && a[i]<a[Dque[Back]])
Back--;
Dque[++Back]=i;
if (Dque[Front]==i-k)
Front++;
if(i>k)
sum+=a[Dque[Front]];
}
g<<sum;
f.close();
g.close();
return 0;
}
