Pagini recente » Cod sursa (job #1537725) | Cod sursa (job #1095634) | Cod sursa (job #1258011) | Cod sursa (job #2447263) | Cod sursa (job #2738230)
#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;
}