Cod sursa(job #236791)

Utilizator c_e_manuEmanuel Cinca c_e_manu Data 28 decembrie 2008 15:04:55
Problema Secv Scor 20
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.82 kb
#include<cstdio>
#include<algorithm>
#define INF 50002

using namespace std;

int v[50001],c[50001],a[50001],i,j=1,n,m,x,minim=INF;

int main()
{       freopen("secv.in","r",stdin);
        freopen("secv.out","w",stdout);
        scanf("%d",&n);
        for(i=1;i<=n;i++)
        {       scanf("%d",&a[i]);
                v[i]=a[i];
        }
        sort(v+1,v+n+1);
        for(i=1;i<=n;i++)
                if(v[i]!=c[j-1]) c[j++]=v[i];
        --j;m=j;
        for(x=1;x<=n;x++)
                if(a[x]==c[1])
                {       i=x;
                        for(j=2;j<=m&&i<=n;i++)
                                if(a[i]==c[j]) j++;
                        if(j==m+1&&i-x<minim) minim=i-x;
                }
        if(minim!=INF) printf("%d\n",minim);
        else printf("-1\n");
        return 0;
}