動態主席樹模板
推薦博文
https://blog.csdn.net/WilliamSun0122/article/details/77885781
模板
#include <bits/stdc++.h>
using namespace std;
const int maxn = 6e4+5;
const int maxm = 1e4+5;
int T[maxn],S[maxn],L[maxn*32],R[maxn*32],sum[maxn*32];
int sz[maxn],h[maxn];
int ul[maxn],ur[maxn];
int tot,num,n,q;
struct node{
int l,r,k;
bool flag; //ture代表Q,false代表C
}Q[maxm]; //儲存詢問
void build(int& rt,int l,int r)
{
rt = ++tot;
sum[rt]=0;
if(l==r) return;
int mid = (l+r)>>1;
build(L[rt],l,mid);
build(R[rt],mid+1,r);
}
void update(int& rt,int pre,int l,int r,int x,int val)
{
rt = ++tot;
L[rt] = L[pre];
R[rt] = R[pre];
sum[rt] = sum[pre]+val;
if(l==r) return;
int mid = (l+r)>>1;
if(x<=mid) update(L[rt],L[pre],l,mid,x,val);
else update(R[rt],R[pre],mid+1,r,x,val);
}
int lowbit(int x)
{
return x&(-x);
}
void add(int x,int val)
{
int res = lower_bound(h+1,h+1+num,sz[x])-h;
while(x<=n)
{
update(S[x],S[x],1,num,res,val);
x += lowbit(x);
}
}
int Sum(int x,bool flag)
{
int res=0;
while(x>0)
{
if(flag) res += sum[L[ur[x]]];
else res += sum[L[ul[x]]];
x -= lowbit(x);
}
return res;
}
int query(int s,int e,int ts,int te,int l,int r,int k)
{
if(l==r) return l;
int mid = (l+r)>>1;
int res = Sum(e,true)-Sum(s,false)+sum[L[te]]-sum[L[ts]];
if(k<=res)
{
for(int i=e;i;i-=lowbit(i)) ur[i] = L[ur[i]];
for(int i=s;i;i-=lowbit(i)) ul[i] = L[ul[i]];
return query(s,e,L[ts],L[te],l,mid,k);
}
else
{
for(int i=e;i;i-=lowbit(i)) ur[i] = R[ur[i]];
for(int i=s;i;i-=lowbit(i)) ul[i] = R[ul[i]];
return query(s,e,R[ts],R[te],mid+1,r,k-res);
}
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
char str[5];
num=0;
scanf("%d%d",&n,&q);
for(int i=1;i<=n;i++) scanf("%d",sz+i),h[++num]=sz[i];
for(int i=1;i<=q;i++)
{
scanf("%s",str);
if(str[0]=='Q')
{
scanf("%d%d%d",&Q[i].l,&Q[i].r,&Q[i].k);
Q[i].flag=true;
}
else
{
scanf("%d%d",&Q[i].l,&Q[i].r);
Q[i].flag=false;
h[++num]=Q[i].r;
}
}
sort(h+1,h+1+num);
int tmp = unique(h+1,h+1+num)-h-1;
num = tmp;
tot=0;
build(T[0],1,num);
for(int i=1;i<=n;i++) update(T[i],T[i-1],1,num,lower_bound(h+1,h+1+num,sz[i])-h,1);
for(int i=1;i<=n;i++) S[i] = T[0];
for(int i=1;i<=q;i++)
{
if(Q[i].flag)
{
for(int j=Q[i].r;j;j-=lowbit(j)) ur[j] = S[j];
for(int j=Q[i].l-1;j;j-=lowbit(j)) ul[j] = S[j];
printf("%d\n",h[query(Q[i].l-1,Q[i].r,T[Q[i].l-1],T[Q[i].r],1,num,Q[i].k)]);
}
else
{
add(Q[i].l,-1);
sz[Q[i].l] = Q[i].r;
add(Q[i].l,1);
}
}
}
return 0;
}
相關文章
- 主席樹模板
- 主席樹
- 【主席樹】P3919 【模板】可持久化線段樹 1持久化
- 洛谷 - P3690 【模板】Link Cut Tree (動態樹)(LCT模板)
- 洛谷 P3919 可持久化線段樹 1 之主席樹模板(初級)持久化
- Link-Cut Tree(LCT) 模板總結 & 水題/模板題 動態樹
- 【題解】Solution Set - NOIP2024集訓Day3 權值線段樹、動態開點、主席樹
- 模板 - 動態規劃動態規劃
- 【資料結構】淺談主席樹資料結構
- SPOJ TTM To the moon(主席樹+區間操作)
- BZOJ4299: Codechef FRBSUM(主席樹)
- 演算法隨筆——主席樹(可持久化線段樹)演算法持久化
- freemarker根據靜態模板和動態模板生成PDF與Word
- bzoj3439: Kpm的MC密碼(主席樹+DFS序+字典樹)密碼
- 線段樹模板
- 【模板】珂朵莉樹
- BZOJ3589 : 動態樹
- 動態開點線段樹
- SPOJ DQUERY (離線數狀陣列||線上主席樹)陣列
- LCT總結——概念篇+洛谷P3690[模板]Link Cut Tree(動態樹)(LCT,Splay)
- Excel模板匯出之動態匯出Excel
- 怎樣處理包含的動態模板
- 可持久化線段————主席樹(洛谷p3834)持久化
- BZOJ 3589 動態樹(子樹操作,鏈查詢)
- 【模板】最小生成樹
- 2024年3月21日 懸繩法 + 珂朵莉樹(ODT) + 主席樹
- 四步模板解決動態規劃動態規劃
- bzoj4477: [Jsoi2015]字串樹(主席樹+Hash+Lca)JS字串
- Bzoj 1901 Zju2112 Dynamic Rankings(樹狀陣列+主席樹)陣列
- CF 220E Little Elephant and Inversions(主席樹+two points)
- 動態開點線段樹說明
- 動態menu導航條以及treeview樹View
- 線段樹模板總結
- 模板口胡:樹同構
- 【模板】最小生成樹-kruskal
- 聊聊elasticsearch7.8的模板和動態對映Elasticsearch
- Ajax 應用模板(動態載入列表框)
- 線段樹+差分——【模板】樹狀陣列2陣列