Cod sursa(job #751163)

Utilizator costyrazvyTudor Costin Razvan costyrazvy Data 24 mai 2012 18:47:30
Problema Subsir crescator maximal Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 0.54 kb
#include <fstream>

using namespace std;
int a[100000],q[100000],p[100000],i,j,n,mx,mij,st,dr,l,pz;
int main()
{
    ifstream f("scmax.in");
    ofstream g("scmax.out");
    f>>n;
    for (i=1; i<=n; i++) f>>a[i];
    q[1]=a[1];l=1;
    for (i=2;i<=n;i++) {
    st=1;dr=l;pz=0;
    while (st<= dr && pz==0 ){ mij=(st+dr)/2;
    if (q[mij]==a[i] ) pz=mij;else if (q[mij]>a[i]) dr=mij-1; else st=mij+1; }
    if (pz==0) pz=st;
    q[pz]=a[i];
    if (st>l) l=st;
    p[i]=pz;
    if (p[i]>mx) mx=p[i];}
    g<<mx;
    return 0;
}