Pagini recente » Cod sursa (job #1916803) | Cod sursa (job #703507) | Cod sursa (job #3228921) | Cod sursa (job #2426343) | Cod sursa (job #1413666)
#include<fstream>
#include <climits>
using namespace std;
ifstream cin("scmax.in");
ofstream cout("scmax.out");
int main()
{
long n,lung[100001],a[100001],maxim=INT_MIN;
int i,j;
cin>>n;
for(i=1;i<=n;++i)
cin>>a[i];
for(i=n;i>=1;--i){
lung[i]=1;
for( j=n;j>i;--j )
{
if( a[i] < a[j] && lung[i] <1 + lung[j] )
lung[i]=lung[j]+1;
}
if(lung[i]>maxim)
maxim=lung[i];
}
cout<<maxim<<"\n";
for(i=1;i<=n;++i)
if(lung[i]==maxim)
{
cout<<a[i]<<" ";
maxim--;
}
return 0;
}