Pagini recente » Cod sursa (job #35462) | Cod sursa (job #1167354) | Cod sursa (job #1437782) | Cod sursa (job #2046745) | Cod sursa (job #664660)
Cod sursa(job #664660)
#include<fstream>
using namespace std;
ifstream f("scmax.in");
ofstream g("scmax.out");
int a[100005],x[100005],l[100005],n,nr,lmax,i,poz,k;
int cautare(int a,int x[100005])
{
int p,u,mij;
p=1;
u=nr;
while(p<=u)
{
mij=(p+u)/2;
if(a==x[mij])
{
return mij;
}
else
{
if(x[mij]>a)
{
u=mij-1;
}
else
{
p=mij+1;
}
}
}
return p;
}
void afisare(int p)
{
int i,t;
if(l[p]>1)
{
for(i=p-1;i>0;i--)
{
if(l[i]+1==l[p] && a[i]<a[p])
{
t=i;
break;
}
}
afisare(t);
g<<a[p]<<' ';
}
else
{
g<<a[p]<<' ';
}
}
int main()
{
f>>n;
f>>a[1];
x[1]=a[1];
l[1]=lmax=nr=1;
for(i=2;i<=n;i++)
{
f>>a[i];
poz=cautare(a[i],x);
x[poz]=a[i];
l[i]=poz;
if(poz>nr)
{
nr++;
}
if(lmax<l[i])
{
lmax=l[i];
k=i;
}
}
g<<lmax<<'\n';
afisare(k);
return 0;
}