Pagini recente » Cod sursa (job #178175) | Cod sursa (job #292632) | Cod sursa (job #641018) | Cod sursa (job #1799134) | Cod sursa (job #1797024)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("scmax.in");
ofstream g("scmax.out");
#define MAXN 100010
int n,v[MAXN],poz[MAXN],tata[MAXN],maxim,j,x;
void afis(int nod)
{
if(nod==0)
return;
afis(tata[nod]);
g<<nod<<' ';
}
int main()
{
f>>n;
for(int i=1;i<=n;i++)
{
f>>v[i];
j=1;
while(poz[j]<v[i]&&j<=maxim)
j++;
poz[j]=v[i];
tata[v[i]]=poz[j-1];
if(j>maxim)
{
maxim=j;
x=v[i];
}
}
g<<maxim<<'\n';
afis(x);
return 0;
}