Pagini recente » Cod sursa (job #162860) | Cod sursa (job #3134556) | Profil MihaelaCismaru | Cod sursa (job #872830) | Cod sursa (job #1530136)
#include <fstream>
#define lng 100000
#include <stack>
using namespace std;
ifstream fin("scmax.in");
ofstream fout("scmax.out");
long long a[lng];
long long b[lng];
stack <long long> S;
int main()
{
int n;
fin>>n;
for(int i=0;i<n;i++)
fin>>a[i];
int max1;
int max2=0;
b[0]=1;
for(int i=1;i<n;i++)
{
max1=1;
for(int j=i-1;j>0;j--)
{
if(a[j]<a[i])
{
if(b[j] + 1 > max1)
{
max1=b[j] + 1;
}
}
}
b[i]=max1;
if(max1>max2) max2=max1;
}
int copmax=max2;
for(int i=n-1;i>=0;i--)
if(b[i]==copmax)
{
S.push(a[i]);
copmax--;
}
fout<<max2<<"\n";
while(S.size())
{
fout<<S.top()<<" ";
S.pop();
}
fin.close();
fout.close();
return 0;
}