题面

单点修改,区间求第k大

分析

首先,这道题卡权值线段树套treap的做法,所以只能用主席树做

对于静态的查询,root[i]对应的主席树的区间[l,r]保存的是a[1]a[i]有多少个值落在区间[l,r]内。如果我们要修改a[i],则要修改O(n)棵主席树。那么我们像树状数组那样维护n棵主席树,不同的是每棵主席树里保存的是,a[i-lowbit(i)+1]a[i]有多少个值落在区间[l,r]内

对于查询[ql,qr]时的做差

我们要像树状数组求和那样,把root[i],root[i-lowbit(i)],....共O(logn)棵主席树的值加起来,才能得到a[1]a[i]有多少个数落在1qr里面,1~(ql-1)同理,维护两个临时数组x,y存储这O(logn)棵主席树的根即可

对于单点修改,我们像树状数组修改那样,往O(logn)棵主席树中插入即可

时间复杂度\(O(n \log ^2 n)\),空间复杂度略大,为\(O(n\log^2n)\)

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<ctime>
#include<algorithm>
#define maxn 200005
#define maxlogn 27
using namespace std;
inline void qread(int& x) {
x=0;
char c=getchar();
int sign=1;
while(c<'0'||c>'9') {
if(c=='-') sign=-1;
c=getchar();
}
while(c>='0'&&c<='9') {
x=x*10+c-'0';
c=getchar();
}
x*=sign;
}
inline void qread(char &x){
char c=getchar();
while(c<'A'||c>'Z'){
c=getchar();
}
x=c;
}
inline void qprint(int x) {
if(x<0) {
putchar('-');
qprint(-x);
} else if(x==0) {
putchar('0');
return;
} else {
if(x/10>0) qprint(x/10);
putchar('0'+x%10);
}
} int n,m;
struct node {
int ls;
int rs;
int sum;
} tree[maxn*maxlogn*maxlogn];
int root[maxn*maxlogn];
int ptr;
void push_up(int x) {
tree[x].sum=tree[tree[x].ls].sum+tree[tree[x].rs].sum;
}
void update(int &x,int upos,int uval,int last,int l,int r) {
x=++ptr;
tree[x]=tree[last];
if(l==r) {
tree[x].sum+=uval;
return;
}
int mid=(l+r)>>1;
if(upos<=mid) update(tree[x].ls,upos,uval,tree[last].ls,l,mid);
else update(tree[x].rs,upos,uval,tree[last].rs,mid+1,r);
push_up(x);
}
int totx,x[maxn*maxlogn],toty,y[maxn*maxlogn];
int query(int k,int l,int r) {
if(l==r) return l;
int lcnt=0;
int mid=(l+r)>>1;
for(int i=1;i<=totx;i++){
lcnt-=tree[tree[x[i]].ls].sum;
}
for(int i=1;i<=toty;i++){
lcnt+=tree[tree[y[i]].ls].sum;
}
if(k<=lcnt){
for(int i=1;i<=totx;i++) x[i]=tree[x[i]].ls;
for(int i=1;i<=toty;i++) y[i]=tree[y[i]].ls;
return query(k,l,mid);
}else{
for(int i=1;i<=totx;i++) x[i]=tree[x[i]].rs;
for(int i=1;i<=toty;i++) y[i]=tree[y[i]].rs;
return query(k-lcnt,mid+1,r);
}
}
inline int lowbit(int x){
return x&-x;
} struct oper {
int type;
int l,r,k;
int pos,val;
int dval;
} q[maxn];
int a[maxn];
int sz;
int b[maxn*2]; void add(int xpos,int xval,int v){
for(int i=xpos;i<=sz;i+=lowbit(i)){
update(root[i],xval,v,root[i],1,sz);
}
}
int answer(int l,int r,int k){
totx=toty=0;
for(int i=l-1;i;i-=lowbit(i)) x[++totx]=root[i];
for(int i=r;i;i-=lowbit(i)) y[++toty]=root[i];
return query(k,1,sz);
}
int main() {
char cmd;
qread(n);
qread(m);
for(int i=1; i<=n; i++) {
qread(a[i]);
b[++sz]=a[i];
}
for(int i=1; i<=m; i++) {
qread(cmd);
if(cmd=='Q') {
q[i].type=0;
qread(q[i].l);
qread(q[i].r);
qread(q[i].k);
} else {
q[i].type=1;
qread(q[i].pos);
qread(q[i].val);
b[++sz]=q[i].val;
}
}
sort(b+1,b+1+sz);
sz=unique(b+1,b+1+sz)-b-1;
for(int i=1; i<=n; i++) a[i]=lower_bound(b+1,b+1+sz,a[i])-b;
for(int i=1; i<=m; i++) {
if(q[i].type==1) {
q[i].dval=lower_bound(b+1,b+1+sz,q[i].val)-b;
}
}
for(int i=1; i<=n; i++) {
add(i,a[i],1);
}
// T2.debug(1);
for(int i=1; i<=m; i++) {
if(q[i].type==0) {
qprint(b[answer(q[i].l,q[i].r,q[i].k)]);
putchar('\n');
} else {
add(q[i].pos,a[q[i].pos],-1);
add(q[i].pos,q[i].dval,1);
a[q[i].pos]=q[i].dval; // T2.debug(1);
}
}
}

[BZOJ1901][luogu2617]Dynamic Rankings(树状数组+主席树)的更多相关文章

  1. BZOJ_1901_Zju2112 Dynamic Rankings_树状数组+主席树

    BZOJ_1901_Zju2112 Dynamic Rankings_树状数组+主席树 题意: 给定一个含有n个数的序列a[1],a[2],a[3]……a[n],程序必须回答这样的询问:对于给定的i, ...

  2. zoj2112 树状数组+主席树 区间动第k大

    Dynamic Rankings Time Limit: 10000MS   Memory Limit: 32768KB   64bit IO Format: %lld & %llu Subm ...

  3. 【bzoj1146】[CTSC2008]网络管理Network 倍增LCA+dfs序+树状数组+主席树

    题目描述 M公司是一个非常庞大的跨国公司,在许多国家都设有它的下属分支机构或部门.为了让分布在世界各地的N个部门之间协同工作,公司搭建了一个连接整个公司的通信网络.该网络的结构由N个路由器和N-1条高 ...

  4. 【bzoj3744】Gty的妹子序列 分块+树状数组+主席树

    题目描述 我早已习惯你不在身边, 人间四月天 寂寞断了弦. 回望身后蓝天, 跟再见说再见…… 某天,蒟蒻Autumn发现了从 Gty的妹子树(bzoj3720) 上掉落下来了许多妹子,他发现 她们排成 ...

  5. BZOJ_2120_数颜色_Set+树状数组+主席树

    BZOJ_2120_数颜色_Set+树状数组+主席树 Description 墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会像你发布如下指令: 1. Q L ...

  6. P1972 [SDOI2009]HH的项链[离线+树状数组/主席树/分块/模拟]

    题目背景 无 题目描述 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH 不断地收集新的贝壳,因此,他的项链 ...

  7. [luogu2617][bzoj1901][Zju2112]Dynamic Rankings【树套树+树状数组+主席树】

    题目网址 [传送门] 题目大意 请你设计一个数据结构,支持单点修改,区间查询排名k. 感想(以下省略脏话inf个字) 真的强力吹爆洛谷数据,一般的树套树还给我T了一般的点,加强的待修主席树还给我卡了几 ...

  8. ZOJ 2112 Dynamic Rankings(树状数组+主席树)

    The Company Dynamic Rankings has developed a new kind of computer that is no longer satisfied with t ...

  9. ZOJ 2112 Dynamic Rankings(树状数组+主席树)

    题意 \(n\) 个数,\(m\) 个操作,每次操作修改某个数,或者询问某个区间的第 \(K\) 小值. \(1 \leq n \leq 50000\) \(1 \leq m \leq 10000\) ...

随机推荐

  1. gay绿论第一章两点注意事项

    1.不可能事件的概率为0,但概率为0的事件不一定是不可能事件,例如从自然数中取一个数结果是1的概率,从极限角度看,分子是1,分母是∞,结果是0,但它显然是有可能发生的,所以不是不可能事件. 2.两事件 ...

  2. oralce 汇编02

    Assembler Directives .align integer, padThe .align directive causes the next data generated to be al ...

  3. Linux 部署或升级openssh7.5p1

    运维Linux系统,部署或升级openssh是经常面临的事,以下已redhat6和redhat7为例. 在redhat6中部署openssh会有什么坑,在编辑openssh源码包时会报一些类似的错误, ...

  4. [CF] 8C Looking for Order

    状压模板题 CF难度2000? 我得好好了解一下CF的难度机制了 反正CF的难度比洛谷真实就好了 Code #include<algorithm> #include<iostream ...

  5. PCB项目 X1 STC12C5A60S2-LQPF48

    单片机控制系统双层板STC51 简介: STC12C5A60S2主芯片,12MHz主频 12V电源输入,12/5/3V电源输出 4路0~12V可调10位ADC输入 4路1A大电流达林顿输出 4路INT ...

  6. 前端每日实战:21# 视频演示如何用纯 CSS 创作文本滑动特效的 UI 界面

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/QrxxaW 可交互视频教程 此视频 ...

  7. 从Excel粘到Word的图片只有下面一半

    把图片粘贴到WORD上为什么只显示最底下一部分? 出现此故障的原因,有可能是设置为固定值的文档行距小于图形的高度,从而导致插入的图形只显示出了一部分.所以要调整图片的段落格式中的行间距. 解决方法 选 ...

  8. fast

    # connect timeout in seconds# default value is 30sconnect_timeout=30 # network timeout in seconds# d ...

  9. NIO拷贝

  10. FastDFS介绍(一)

    1.简介 FastDFS对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载.文件删除)等,解决了大容量文件存储的问题,特别适合以文件为载体的在线服务,如相册网站.文档网站.图片 ...