Cod sursa(job #1507556)

Utilizator aetherAlexandra Vanca aether Data 21 octombrie 2015 19:01:03
Problema Deque Scor 25
Compilator cpp Status done
Runda Arhiva educationala Marime 0.67 kb
# include <fstream>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
long n, k, i, prim, ulti;
int main()
{
    f>>n>>k;
    long v[n], deq[n], sum=0;
    for (i=1; i<=n; i++)
    {
        f>>v[i];
    }
    prim=1; ulti=0;
    for (i=1; i<=n; i++)
    {
        while (prim<=ulti && v[i]<v[deq[ulti]]) //nu a ajuns la deq vid si mai pot scoate elem. din deq
            ulti--;
        deq[++ulti]=i; //pun poztia pe care se gaseste minimul
        if (deq[prim]==i-k)
            prim++; //daca nu se mai gaseste in secventa de k elem., il elimin
        if (i>=k)
            sum+=v[deq[prim]];
    }
    g<<sum;
    return 0;

}