樹狀數組求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]);
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM