Cod sursa(job #2738230)

Utilizator Alexandru_GaloiuAlexandru Galoiu Alexandru_Galoiu Data 5 aprilie 2021 16:37:15
Problema Secv Scor 10
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.99 kb
#include <fstream>
#include <algorithm>
using namespace std;
ifstream cin("secv.in");
ofstream cout("secv.out");
int v[5001],c[5001],f[5001],l[5001],p[5001];
int main()
{
    int n,k=1,lmin=5001;
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>v[i];
        c[i]=v[i];
    }
    sort(c+1,c+n+1);
    f[1]=c[1];
    for(int i=2;i<=n;i++)
        if(c[i]!=c[i-1])
            f[++k]=c[i];
    for(int i=1;i<=n;i++)
    {
        if(v[i]!=f[1])
        {
            int ok=1;
            for(int j=i-1;j&&ok;j--)
                if(v[i]==f[l[j]+1])
                {
                    ok=0;
                    l[i]=l[j]+1;
                    p[i]=p[j];
                }
        }
        else
        {
            l[i]=1;
            p[i]=i;
        }
        if(v[i]==f[k])
        {
            int lc=i-p[i]+1;
            if(lc<lmin)
                lmin=lc;
        }
    }
    if(lmin==5001)
        cout<<-1;
    else cout<<lmin;
    return 0;
}