Cod sursa(job #2299319)

Utilizator Tofan_GhenadieTofan Ghenadie Tofan_Ghenadie Data 9 decembrie 2018 12:18:56
Problema Deque Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.57 kb
#include <iostream>
#include <fstream>
using namespace std;
int t[5000000],dq[5000003],i,k,j,n,p,u;
void adauga(int poz)
{
    if(i>=k&&dq[p]==i-k)p++;
    while(u>=p&&t[dq[u]]>t[poz])u--;
    u++;
    dq[u]=poz;
}
int main()
{
    ifstream fin("deque.in");
    ofstream fout("deque.out");
    fin>>n>>k;
    for(i=1;i<=n;i++)
        fin>>t[i];
    p=1;
    u=0;
    long long int sum=0;
    for(i=1;i<=k;i++)
    {
        adauga(i);

    }
    sum+=dq[1];
    for(i=k+1;i<=n;i++)
    {
        adauga(i);
        sum+=dq[p];

    }
    fout<<sum;
}