Răspuns:
#include <iostream>
using namespace std;
int v[10000],n,i,L[1000],maxim,mx,k,t;
int main()
{cout<<"Cel mai lung subsir crescator"<<endl;
cout<<"n="; cin>>n;
for(i=1;i<=n;i++)
{cout<<"v["<<i<<"]=";
cin>>v[i];}
L[n]=1; //subsir maxim de lung 1
for(k=n-1;k>0;k--)
{mx=0;
for(i=k+1;i<=n;i++)
if(v[i]>=v[k] && L[i]>mx) mx=L[i];
L[k]=mx+1;
if(L[k]>maxim) {maxim=L[k]; t=k;} }
cout<<"lungimea maxima:"<<maxim; //afisarea subsirului
cout<<endl<<v[t]<<' ';
for(i=t+1;i<=n;i++)
if ((v[i]>=v[t]) && (L[i]==maxim-1))
{cout<<v[i]<<' '; maxim--;}
return 0;
}
O aveam facută de la clasă, nu mă pricep neapărat să explic. Sper să te ajute tho :)