Cod sursa(job #453870)

Utilizator suzanicaSuzanica Mihu suzanica Data 11 mai 2010 15:13:57
Problema Subsir crescator maximal Scor 70
Compilator cpp Status done
Runda Arhiva educationala Marime 0.7 kb
#include<fstream>
using namespace std;

int v[10003] , l[10003] , n , i , k , maxim , t;


int main()
{
  ifstream f("scmax.in");
  ofstream g("scmax.out");
  f>>n;
   for(i = 1 ; i <= n ; i++)
    f>>v[i];
  l[n] = 1;
   for(k = n - 1 ; k >= 1 ; k--)
    {
      maxim = 0;
       for(i = k + 1 ; i <= n ; i++)
	if(v[i] > v[k] && l[i] > maxim)
	  maxim = l[i];
       l[k] = 1 + maxim;
    }
   maxim = l[1];
   t = 1;
    for(k = 1 ; k <= n ; k++)
     if(l[k] > maxim)
      {
	maxim = l[k];
	t = k;
      }
   g<<maxim<<"\n"<<v[t]<<" ";
    for(i = t + 1 ; i <= n ; i++)
     if(v[i] > v[t] && l[i] == maxim - 1)
      {
	g<<v[i]<<" ";
	maxim--;
      }
    
    return 0;
}