Pagini recente » Cod sursa (job #2613330) | Cod sursa (job #2111928) | Cod sursa (job #690761) | Cod sursa (job #3247326) | Cod sursa (job #1928579)
#include <fstream>
using namespace std;
ifstream fin("pb2.in");
ofstream fout("pb2.out");
int v[1002];
int pred[1002];//pozitia predecesorului
int l[1002];//lungimea maxima a subsirului pana la v[i]
void afis(int n)
{
if(pred[n]>0)
{
afis(pred[n]);
fout<<v[pred[n]]<<" ";
}
}
int main()
{
int n,poz;
fin>>n;
for(int i=1;i<=n;i++)
{
fin>>v[i];
}
l[1]=1;
pred[1]=0;
poz=0;
for(int i=2;i<=n;i++)
{
l[i]=1;
for(int j=1;j<=i-1;j++)
{
if(v[i]>v[j]&&l[j]+1>l[i])
{
l[i]=l[j]+1;
pred[i]=j;
}
}
if(l[i]>l[poz])
{
poz=i;
}
}
fout<<l[poz]<<"\n";
afis(poz);
fout<<v[poz];
return 0;
}