Pagini recente » Cod sursa (job #629022) | Cod sursa (job #1056156) | Cod sursa (job #1082736) | Cod sursa (job #956103) | Cod sursa (job #912018)
Cod sursa(job #912018)
#include<fstream>
#define NMAX 5005
using namespace std;
FILE *fin,*fout;
int a[NMAX],b[NMAX],n,dif,m;
void scmax()
{
int i,j,m;
for(i=0;i<n;i++)
{
b[i]=1;
m=0;
for(j=i-1;j>=0;j--)
if(a[j]<a[i])
m=(m<b[j])?(b[j]):(m);
b[i]=m+1;
}
}
void dist()
{
int i,p;
for(i=0;i<n;i++)
if(b[i]>m)
{
p=i;
m=b[i];
}
if(m<2)
{
dif=-1;
return;
}
dif=p+1;
for(;m>1;m--,p=i)
{
i=p-1;
while(1)
{
if(a[i]<a[p] && b[i]==m-1)
break;
i--;
}
}
dif-=p;
}
void read()
{
fin=fopen("secv.in","r");
fscanf(fin,"%d",&n);
for(int i=0;i<n;i++)
fscanf(fin,"%d",&a[i]);
fclose(fin);
}
void print()
{
fout=fopen("secv.out","w");
fprintf(fout,"%d",dif);
fclose(fout);
}
int main()
{
read();
scmax();
dist();
print();
return 0;
}