LUOGU P2617 Dynamic Rankings(树状数组套主席树)
解题思路
动态区间第\(k\)大,树状数组套主席树模板。树状数组的每个位置的意思的是每棵主席树的根,维护的是一个前缀和。然后询问的时候\(log\)个点一起做前缀和,一起移动。时空复杂度\(O(nlog^2n)\)。
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int N=100005;
const int M=200005*18*18;
inline int rd(){
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)) f=ch=='-'?0:1,ch=getchar();
while(isdigit(ch)) x=(x<<1)+(x<<3)+ch-'0',ch=getchar();
return f?x:-x;
}
int n,m,tmp[25][2],a[N],cpy[N<<1],u,cnt,rt[N];
int cnt0,cnt1;
struct Segment_tree{
int ls,rs,w;
}t[M];
struct Ask{
int op,l,r,k;
}q[N];
void update(int &x,int l,int r,int pos,int val){
if(!x) x=++cnt;t[x].w+=val;
if(l==r) return ;int mid=(l+r)>>1;
if(pos<=mid) update(t[x].ls,l,mid,pos,val);
else update(t[x].rs,mid+1,r,pos,val);
}
inline void prepare_update(int x,int val){
int now=lower_bound(cpy+1,cpy+1+u,a[x])-cpy;
for(int i=x;i<=n;i+=i&-i) update(rt[i],1,u,now,val);
}
int query(int l,int r,int k){
if(l==r) return l;int sum=0,mid=(l+r)>>1;
for(int i=1;i<=cnt1;i++) sum+=t[t[tmp[i][1]].ls].w;
for(int i=1;i<=cnt0;i++) sum-=t[t[tmp[i][0]].ls].w;
if(sum>=k){
for(int i=1;i<=cnt0;i++) tmp[i][0]=t[tmp[i][0]].ls;
for(int i=1;i<=cnt1;i++) tmp[i][1]=t[tmp[i][1]].ls;
return query(l,mid,k);
}
else {
for(int i=1;i<=cnt0;i++) tmp[i][0]=t[tmp[i][0]].rs;
for(int i=1;i<=cnt1;i++) tmp[i][1]=t[tmp[i][1]].rs;
return query(mid+1,r,k-sum);
}
}
inline int prepare_query(int l,int r,int k){
memset(tmp,0,sizeof(tmp));cnt0=cnt1=0;
for(int i=l-1;i;i-=i&-i) tmp[++cnt0][0]=rt[i];
for(int i=r;i;i-=i&-i) tmp[++cnt1][1]=rt[i];
return query(1,u,k);
}
int main(){
n=rd(),m=rd();char c;int num=n;
for(int i=1;i<=n;i++) cpy[i]=a[i]=rd();
for(int i=1;i<=m;i++) {
c=' ';while(c!='Q' && c!='C') c=getchar();
if(c=='C') q[i].op=1,q[i].l=rd(),q[i].k=rd(),cpy[++num]=q[i].k;
else q[i].op=2,q[i].l=rd(),q[i].r=rd(),q[i].k=rd();
}
sort(cpy+1,cpy+1+num);
u=unique(cpy+1,cpy+1+num)-cpy-1;
for(int i=1;i<=n;i++) prepare_update(i,1);
for(int i=1;i<=m;i++){
if(q[i].op==1){
prepare_update(q[i].l,-1);
a[q[i].l]=q[i].k;
prepare_update(q[i].l,1);
}
else printf("%d\n",cpy[prepare_query(q[i].l,q[i].r,q[i].k)]);
}
return 0;
}
LUOGU P2617 Dynamic Rankings(树状数组套主席树)的更多相关文章
- P2617 Dynamic Rankings(树状数组套主席树)
P2617 Dynamic Rankings 单点修改,区间查询第k大 当然是无脑树套树了~ 树状数组套主席树就好辣 #include<iostream> #include<cstd ...
- BZOJ 1901 Zju2112 Dynamic Rankings ——树状数组套主席树
[题目分析] BZOJ这个题目抄的挺霸气. 主席树是第一时间想到的,但是修改又很麻烦. 看了别人的题解,原来还是可以用均摊的思想,用树状数组套主席树. 学到了新的姿势,2333o(* ̄▽ ̄*)ブ [代 ...
- ZOJ 2112 Dynamic Rankings(树状数组套主席树 可修改区间第k小)题解
题意:求区间第k小,节点可修改 思路:如果直接用静态第k小去做,显然我更改一个节点后,后面的树都要改,这个复杂度太高.那么我们想到树状数组思路,树状数组是求前缀和,那么我们可以用树状数组套主席树,求出 ...
- 【Luogu】P2617Dynamic Ranking(树状数组套主席树)
题目链接 树状数组套主席树有点难懂qwq 不好理解 树状数组套主席树的直观理解应该是:树状数组的每一个节点是一棵主席树. 普通区间修改我们是创建1个线段树,树状数组套主席树的时候我们就创建log个线段 ...
- BZOJ 3196 Tyvj 1730 二逼平衡树 ——树状数组套主席树
[题目分析] 听说是树套树.(雾) 怒写树状数组套主席树,然后就Rank1了.23333 单点修改,区间查询+k大数查询=树状数组套主席树. [代码] #include <cstdio> ...
- BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树
BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排 ...
- [COGS257]动态排名系统 树状数组套主席树
257. 动态排名系统 时间限制:5 s 内存限制:512 MB [问题描述]给定一个长度为N的已知序列A[i](1<=i<=N),要求维护这个序列,能够支持以下两种操作:1.查询A[ ...
- BZOJ 2141 排队(树状数组套主席树)
解法很多的题,可以块套树状数组,可以线段树套平衡树.我用的是树状数组套主席树. 题意:给出一段数列,m次操作,每次操作是交换两个位置的数,求每次操作后的逆序对数.(n,m<=2e4). 对于没有 ...
- 洛谷P3759 [TJOI2017]不勤劳的图书管理员 【树状数组套主席树】
题目链接 洛谷P3759 题解 树状数组套主席树板题 #include<algorithm> #include<iostream> #include<cstring> ...
随机推荐
- 远程仓库(GitHub)的使用
1.注册登录 在 GitHub 上注册登录 暂时忽略不讲 2.创建新的远程仓库 在GitHub网站上创建新的仓库.不管你是先在本地创建仓库还是先在远程创建仓库,要想把代码提交到远程仓库都是要先手动创建 ...
- JDK 与 JRE
JDK就是Java Development Kit.简单的说JDK是面向开发人员使用的SDK,它提供了Java的开发环境和运行环境.SDK是Software Development Kit 一般指软件 ...
- left、pixelLeft、posLeft的区别
yexj00.style.pixelLeft=50yexj00.style.left=50pxyexj00.style.posLeft=50he.style.pixelLeft=39he.style. ...
- 《单词的减法》state1~state17(第二遍学习记录)
单词的减法(二) 2016.05.18.2016.05.21 state 1 advisory 顾问的,劝告的 anticipate/participate 期望/参加 state 2 applian ...
- Linear Regression and Gradient Descent (English version)
1.Problem and Loss Function Linear Regression is a Supervised Learning Algorithm with input matrix ...
- static关键字_1
static关键字 1.在类中,用static声明的成员变量为静态成员变量,它为该类的公用变量,在第一次使用时被初始化,对于该类的所以对象来说,static成员变量只有一份. 2.用static声 ...
- 洛谷 P1462 通往奥格瑞玛的道路——二分+spfa
上一波链接 https://www.luogu.org/problem/P1462 这道题我们考虑二分答案 然后每次跑一次spfa判断是否能够到达n点 tips:在不考虑负权边的前提下我们写最短路最好 ...
- 转 Page Object模式
Page Object模式是Selenium中的一种测试设计模式,主要是将每一个页面设计为一个Class,其中包含页面中需要测试的元素(按钮,输入框,标题 等),这样在Selenium测试页面中可以通 ...
- 分布式服务防雪崩熔断器,Hystrix理论+实战。
Hystrix是什么? hystrix对应的中文名字是"豪猪",豪猪周身长满了刺,能保护自己不受天敌的伤害,代表了一种防御机制,这与hystrix本身的功能不谋而合,因此Netfl ...
- git pull的时候发生冲突的解决方法之“error: Your local changes to the following files would be overwritten by merge”
今天在使用git pull 命令的时候发生了以下报错 目前git的报错提示已经相关友好了,可以直观的发现,这里可以通过commit的方式解决这个冲突问题,但还是想看看其他大佬是怎么解决这类问题的 在网 ...