Thứ Ba, 3 tháng 5, 2022

LIQLIS SUB 3 C++

#include <bits/stdc++.h>
using namespace std;
int n,a[100001],f[100001],b[100001],res=0,maxx=1;
int t[1000005];

void nhap()
{
    cin>>n;
    for(int i=1;i<=n;i++)
        cin>>a[i];
}

int ds[1000005];
void truyvet(int k)
{
    int d=0;
    while(k>0)
    {
        //cout<<k<<" ";
        d++;
        ds[d]=k;
        k=t[k];
    }
    for(int i=d;i>=1;i--)
        cout<<ds[i]<<" ";
}

int bs(int x,int l,int r)
{
    int res=0,m;
    while(l<=r)
    {
        m=(l+r)/2;
        if(a[b[m]]<x)
        {
            res=m;
            l=m+1;
        }
        else r=m-1;
    }
    return b[res];
}

void giai()
{
    int res,jmax;
    f[1]=1;res=1;b[1]=1;
    for(int i=2;i<=n;i++)
    {
        jmax=bs(a[i],1,f[res]);
        f[i]=f[jmax]+1;
        t[i]=jmax;
        b[f[i]]=i;
        if(f[i]>f[res]) res=i;
    }
    cout<<f[res]<<endl;
    truyvet(res);
}

void xuat()
{
    res=maxx;
    for (int i=n;i>=1;i--)
    {
        if (res==f[i])
        {
            a[res]=i;
            res--;
        }
        if (res==0) break;
    }
    cout<<maxx<<endl;
    for (int i=1;i<=maxx;i++) cout<<a[i]<<" ";
}

int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    freopen("liqlis.inp","r",stdin);
    freopen("liqlis.out","w",stdout);
    //xuli();
    //xuat();
    nhap();
    giai();
}

Không có nhận xét nào:

Đăng nhận xét

Lưu ý: Chỉ thành viên của blog này mới được đăng nhận xét.