树状数组求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]);
}

原文链接: https://www.cnblogs.com/sdfzhsz/p/9281436.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍

    树状数组求LIS

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/277306

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年2月15日 上午2:26
下一篇 2023年2月15日 上午2:28

相关推荐