动态区间第k小

题目链接

题意:动态区间第k小就是静态区间第k小加上修改这个功能,静态第k小我们是用主席树做的,但是如果带上修改的功能,主席树保存的是前缀信息,所以说,当修改了一个点的时候,他后面的点都要修改,很明显时间复杂度过不去。所以就用树套树,树状数组套动态开点线段树,树状数组的时间复杂度是logn。这个题写了超久,要不是男神给我debug,估计还要两三天才能写出来。

数组数组的上限是n,不是离散化后的元素个数,因为一共有n个根节点。如果离线做这道题,需要多留一点空间。

#include<bits/stdc++.h>
#define low(x) x&-x
#define mid (l+r)/2
using namespace std;
const int maxn=1e5+100; 
int n,cnt,a[maxn],V[25],S[maxn*210],tot=0,V1[25];
int tot1=0,sz;
int sum[maxn*210],ls[maxn*210],rs[maxn*210],rt[maxn];
struct node{
	char opt[2];
	int ql,qr,k;
}Q[maxn];
void up(int l,int r,int p,int v)
{
	for(int i=1;i<=
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值