Cod sursa(job #495454)

Utilizator gabipurcaruGabi Purcaru gabipurcaru Data 25 octombrie 2010 13:10:36
Problema Subsir 2 Scor 36
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.56 kb
// infoarena: problema/subsir2 //
#include <fstream>
#define MAXN 5010
using namespace std;

ifstream in("subsir2.in");
ofstream out("subsir2.out");

int x[MAXN],i,j,s[MAXN],k[MAXN],m,n,l,p,q,r[MAXN];

int main()
{
	in>>n;
	for(i=1; i<=n; i++)
		in>>x[i];
	
	s[n] = 1;
	for(i=n-1; i>=1; i--)
	{
		m = 0;
		for(j=i+1; j<=n; j++)
			if(x[j] > x[i] && s[j] > s[m])
				m = j;
			
		s[i] = s[m] + 1;
		k[i] = m;
		if(s[q] < s[i])
			q = i;
	}
	
	out<<s[q]<<'\n';
	p = q;
	
	while(p)
	{
		out<<x[p]<<' ';
		p = k[p];
	}
	
	return 0;
}