Pagini recente » Cod sursa (job #2925660) | Cod sursa (job #1768714) | Cod sursa (job #2654772) | Cod sursa (job #558548) | Cod sursa (job #1667261)
#include <iostream>
#include <fstream>
using namespace std;
int a[100005],ss[100005],urm[100005],i,j,sol=0,ras,pozmax,n;
int main()
{ ifstream f("scmax.in");
ofstream g("scmax.out");
f>>n;
for (i=1;i<=n;i++)f>>a[i];
ss[n]=1; urm[n]=-1;
ras=1; pozmax=n;
for (i=n-1;i>=1;i--) {
ss[i]=1;
urm[i]=-1;
for (j=i;j<=n;j++)
if (a[i]<a[j]&&ss[i]<ss[j]+1) {
ss[i]=ss[j]+1;
urm[i]=j;
if(ss[i]>ras){ras=ss[i]; pozmax=i;}
}
}
g<<ras<<"\n";
i=pozmax;
while (i!=-1) {
g<<a[i]<<" ";
i=urm[i];
}
// for (i=pozmax;i!=-1;i=urm[i]) g<<a[i]<<" ";
return 0;
}