Cod sursa(job #1058489)

Utilizator vlady1997Vlad Bucur vlady1997 Data 15 decembrie 2013 16:41:29
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.89 kb
        #include <cstdio>
        #include <deque>
        using namespace std;
        deque <int> h;
        int a[5000001];
        int main()
        {
            int n, k, i;
            signed long long int s=0;
            freopen("deque.in","r",stdin);
            freopen("deque.out","w",stdout);
            scanf("%d%d",&n,&k);
            for (i=1; i<=n; i++) scanf("%d",&a[i]);
            for (i=1; i<=n; i++)
            {
                while(!h.empty() && a[h.back()]>a[i])
                {
                    h.pop_back();
                }
                h.push_back(i);
                while(h.front()<=i-k)
                {
                    h.pop_front();
                }
                if(i>=k) s+=a[h.front()];
            }
            printf("%lld",s);
            fclose(stdin);
            fclose(stdout);
            return 0;
        }