树状数组求LIS

时间:2021-05-13 19:27:34

我真的是咸鱼啊

多少年前的基础了我竟然才弄明白,哭
用树状数组维护<=x的最上上升子序列的最大值即可啊Orz
我真的菜的一笔啊!

#include <bits/stdc++.h>
using namespace std;
map<int,int>mp;
int f[50005],n,t[50005];
void modify(int x,int Max){
    for(int i=x;i<=50004;i+=i&-i) {
        t[i]=max(t[i],Max);
    }
}
int ask(int x) {
    int res=0;
    for(int i=x;i;i-=i&-i) {
        res=max(res,t[i]);
    }
    return res;
}
int main() {
    scanf("%d",&n);
    for(int tp,i=1,x;i<=n;i++) {
        scanf("%d",&x);
        f[i]=ask(x)+1;
        modify(x,f[i]);
    }
    for(int i=1;i<=n;i++)printf("%d ",f[i]);
}