Pagini recente » Cod sursa (job #3158155) | Cod sursa (job #2791530) | Cod sursa (job #2597626) | Cod sursa (job #459676) | Cod sursa (job #215713)
Cod sursa(job #215713)
#include<stdio.h>
int n,v2[5001],lm;
long v[5001];
void read ()
{
FILE *f=fopen("subsir2.in","r");
fscanf(f,"%d",&n);
int i;
for (i=1;i<=n;++i)
fscanf(f,"%ld",&v[i]);
fclose(f);
}
void solve ()
{
int i,j,max;
v2[n]=1;
for (i=n-1;i>=1;--i)
{
max=0;
for (j=i+1;j<=n;++j)
if (v2[j]>max&&v[j]>v[i])
max=v2[j];
v2[i]=max+1;
if (lm<v2[i])
lm=v2[i];
}
}
void drum ()
{
FILE *f;
f=fopen("subsir2.out","w");
int t=0,p=1;
do {
while (v2[p]!=lm||v[t]>v[p])
p++;
fprintf(f,"%d ",p);
t=p;
lm --;
} while (lm);
fclose(f);
}
int main ()
{
read ();
solve ();
drum ();
return 0;
}