题面

单点修改,区间求第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. CentOS7搭建Kafka单机环境及基础操作

    前提 安装Kafka前需要先安装zookeeper集群,集体安装方法请参照我的另一篇文档. Kafka安装 下载 wget https://archive.apache.org/dist/kafka/ ...

  2. webGL 旋转算法

    lon = 0,//y旋转角度 lat = 0, onMouseDownLat = 0, phi = 0, theta = 0; if ( isUserInteracting === false ) ...

  3. SIGINT、SIGQUIT、 SIGTERM、SIGSTOP区别

    2) SIGINT程序终止(interrupt)信号, 在用户键入INTR字符(通常是Ctrl-C)时发出,用于通知前台进程组终止进程. 3) SIGQUIT和SIGINT类似, 但由QUIT字符(通 ...

  4. 【改】shell 判断文件中有无特定子串方法(grep)

    转自:https://blog.csdn.net/zhuguiqin1/article/details/79160923 利用grep执行的命令结束代码$?的值来判断是否已经grep到特定的值. 当$ ...

  5. 简要说明 django restframework 的交互式文档

    现在为了解决前后端交互沟通的问题,不少框架都推出了相关的swage库, 用起来似乎很是友好. 正好最近在开发一个小项目,想到新项目就用新版本新技术的理念,我下载了restframework 3.7的版 ...

  6. Sass-@extend

    Sass 中的 @extend 是用来扩展选择器或占位符.比如: .error { border: 1px #f00; background-color: #fdd; } .error.intrusi ...

  7. Java 静态方法、私有方法、常量的使用

    1.静态方法 2.私有方法 3.常量 4.接口小结

  8. CSP2019初赛训练

    [解释执行语言] C,C++,Pascal都是编译执行的语言,Python是解释执行. 扩展:JS.PHP也是解释运行语言.解释性灵活但是效率较低.一些解释性语言也有了也能在一定程度上编译,或者使用虚 ...

  9. Redirecting to /bin/systemctl restart mysql. service Failed to restart mysql.service: Unit not found.

    使用如下命令操作mysql即可: systemctl restart mysqld.service systemctl start mysqld.service systemctl stop mysq ...

  10. maven编译问题之 -The POM for XXX is invalid, transitive dependencies (if any) will not be available

    问题一: 把父工程tao-parent install 到maven本地仓后,接着install tao-common工程,然后报错 报错信息如下: [WARNING] The POM for com ...