Cod sursa(job #2732486)

Utilizator mihaaelaMihaela Radu mihaaela Data 28 martie 2021 23:25:10
Problema Deque Scor 60
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.59 kb
#include <fstream>

using namespace std;
int MAX_N =500001;

int main()
{
    ifstream fin("deque.in");
    ofstream fout("deque.out");
    int a[MAX_N],deque[MAX_N],n,i,k,x;
    long long sum=0;
    int front=1,back=0;
    fin>>n>>k;
    for(i=1;i<=n;i++)
        fin>>a[i];
    for(i=1;i<=n;i++)
            {
              while(front<=back && a[i]<=a[deque[back]]) back--;
                deque[++back]=i;
              if(deque[front]==i-k) front++;
              if(i>=k)  sum+=a[deque[front]];
            }
    fout<<sum;
    fin.close();
    fout.close();
    return 0;
}