树状数组求LIS

我真的是咸鱼啊

多少年前的基础了我竟然才弄明白,哭
用树状数组维护<=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]);
}
我是咸鱼。转载博客请征得博主同意Orz
原文地址:https://www.cnblogs.com/sdfzhsz/p/9281436.html