题解:

可修改的主席树

一开始,我就按照最暴力的方法,空间nlognlogn

然后zju上面过不了,bzoj没有权限号

然后,参考了往上的论文,发现可以把初始的主席树先建好

然后,每次只需要维护修改的就可以了

而且修改的内容只有2个数字

可以快那么一些

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define ls(x) t[x].lc
#define rs(x) t[x].rc
typedef long long ll;
const int N=;
int read()
{
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return x*f;
}
int q1[N],t1,q2[N],t2,sz=,root[N],rt[N],n,Q,m,a[N],mp[N*],i,j,k;
char s[];
struct question
{
char s[];
int i,j,k,x,d;
}q[N];
struct node
{
int lc,rc,w;
}t[N*];
int Bin(int v)
{
int l=,r=m;
while (l<=r)
{
int mid=(l+r)>>;
if(mp[mid]==v) return mid;
if(mp[mid]>v) r=mid-;
else l=mid+;
}
return -;
}
void ins(int &x,int l,int r,int num,int v)
{
t[++sz]=t[x];x=sz;
t[x].w+=v;
if(l==r) return;
int mid=(l+r)>>;
if (num<=mid) ins(t[x].lc,l,mid,num,v);
else ins(t[x].rc,mid+,r,num,v);
}
void add(int p,int v)
{
int xx=Bin(a[p]);
for (int i=p;i<=n;i+=i&-i) ins(root[i],,m,xx,v);
}
int cal()
{
int sum1=,sum2=;
for (int i=;i<=t1;i++) sum1+=t[ls(q1[i])].w;
for (int i=;i<=t2;i++) sum2+=t[ls(q2[i])].w;
return sum2-sum1;
}
int query(int ql,int qr,int k)
{
int l=,r=m;t1=t2=;
for (int i=ql-;i;i-=i&-i) q1[++t1]=root[i];
for (int i=qr;i;i-=i&-i) q2[++t2]=root[i];
ql--;
ql=rt[ql];qr=rt[qr];
while (l<r)
{
int lsize=cal()+t[ls(qr)].w-t[ls(ql)].w,mid=(l+r)>>;
if (k<=lsize)
{
for (int i=;i<=t1;i++) q1[i]=t[q1[i]].lc;
for (int i=;i<=t2;i++) q2[i]=t[q2[i]].lc;
ql=ls(ql);qr=ls(qr);
r=mid;
}
else
{
for (int i=;i<=t1;i++) q1[i]=t[q1[i]].rc;
for (int i=;i<=t2;i++) q2[i]=t[q2[i]].rc;
ql=rs(ql);qr=rs(qr);
l=mid+;k-=lsize;
}
}
return l;
}
int main()
{
int T=read();
while (T--)
{
m=sz=;
memset(q,,sizeof q);
memset(t,,sizeof t);
memset(rt,,sizeof rt);
memset(root,,sizeof root);
n=read();Q=read();
for (int i=;i<=n;i++)a[i]=mp[++m]=read();
for (int i=;i<=Q;i++)
{
scanf("%s",q[i].s);
if (q[i].s[]=='Q') q[i].i=read(),q[i].j=read(),q[i].k=read();
else q[i].x=read(),q[i].d=mp[++m]=read();
}
sort(mp+,mp++m);
int p=;
for (int i=;i<=m;i++) if(mp[i]!=mp[i-]) mp[++p]=mp[i];
m=p;
for (int i=;i<=n;i++) rt[i]=rt[i-],ins(rt[i],,m,Bin(a[i]),);
for (int i=;i<=Q;i++)
{
if(q[i].s[]=='Q')
printf("%d\n",mp[query(q[i].i,q[i].j,q[i].k)]);
else
{
add(q[i].x,-);
a[q[i].x]=q[i].d;
add(q[i].x,);
}
}
}
return ;
}

zoj2112&&bzoj1901的更多相关文章

  1. [主席树]ZOJ2112 && BZOJ1901 Dynamic Rankings

    题意:n个数,q个询问 (n<=50000, q<=10000) Q x y z 代表询问[x, y]区间里的第z小的数 C x y    代表将(从左往右数)第x个数变成y 上篇介绍了在 ...

  2. ZOJ2112 BZOJ1901 Dynamic Rankings 树套树 带修改的区间第k小

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2112 树套树,线段树套splay或者主席树套树状数组,我抄了一下hzwer ...

  3. bzoj1901&zoj2112&cogs257 Dynamic Rankings(动态排名系统)

    bzoj1901&zoj2112&cogs257 Dynamic Rankings(动态排名系统) cogs zoj bzoj-权限 题解 bzoj和zoj都是骗访问量的233,我没有 ...

  4. BZOJ1901 ZOJ2112 线段树+treap (线段树套线段树)

    BZOJ1901: 线段树套线段树做法: (外层线段树 里层动态开节点的权值线段树) 有一个小小的trick 可以省掉二分变成nlog^2n的 就是把查询的区间都取出来- logn个一起走- 2016 ...

  5. [bzoj1901][zoj2112][Dynamic Rankings] (整体二分+树状数组 or 动态开点线段树 or 主席树)

    Dynamic Rankings Time Limit: 10 Seconds      Memory Limit: 32768 KB The Company Dynamic Rankings has ...

  6. 可修改的区间第K大 BZOJ1901 ZOJ2112

    http://blog.csdn.net/u014492306/article/details/47981315 //变相离线做法 离散化缩小区间范围,做两大个线段树,第一个就是普通的持久化树,有个前 ...

  7. 【树状数组套权值线段树】bzoj1901 Zju2112 Dynamic Rankings

    谁再管这玩意叫树状数组套主席树我跟谁急 明明就是树状数组的每个结点维护一棵动态开结点的权值线段树而已 好吧,其实只有一个指针,指向该结点的权值线段树的当前结点 每次查询之前,要让指针指向根结点 不同结 ...

  8. [BZOJ1901]Zju2112 Dynamic Rankings

    [BZOJ1901]Zju2112 Dynamic Rankings 试题描述 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i ...

  9. zoj2112

    题目:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2112 经典的动态区间第K大. 用树状数组套线段树. 对原数组建一个树 ...

随机推荐

  1. python函数总结

    1.函数是一种子程序.程序员使用函数来减少代码重复,并用于组织或模块化程序.一旦定义了函数,它可以从程序中的许多不同位置被多次调用.参数允许函数具有可更改的部分.函数定义中出现的参数称之为形参,函数调 ...

  2. 25个c#知识点

    网站地址:http://m.3y.uu456.com/mbp_56hl91r1rx5uqa87qrzo_1.html

  3. Python3基础 str format 输出花括号{}

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  4. USB Compound Device,USB复合设备 ; USB Composite Device,USB组合设备【转】

    本文转载自:https://blog.csdn.net/autumn20080101/article/details/52776863 科普下USB复合设备和USB组合设备的区别. 关键字 Commu ...

  5. HDU 5884 Sort(二分+优先队列)

    http://acm.hdu.edu.cn/showproblem.php?pid=5884 题意:有个屌丝设计了一个程序,每次可以将k个数组进行合并,代价为这k个数组总的长度之和.现在另外一个屌丝要 ...

  6. python 编程基础练习 第一天

    python 编程基础练习 第一天: 需求: 1.计算2的38次方,180*0.7输出(精度显示正常), x的y次方,数字倒序输出即345876输出678543,方法越多越好. 2.字符串处理: 1) ...

  7. python 处理命令行参数--转载

    标题写了那么久,现在现在才有时间,整理下自己的思路.首先先总结下自己对sys模块的理解.手册上对sys的描述是系统参数和系统函数,这里的系统实际上是python解释器.这个模块提供了用户可以访问的解释 ...

  8. Android广播接收器里弹出对话框

    不多说,直接上车... public class MyReceiver extends BroadcastReceiver { @Override public void onReceive(fina ...

  9. Java jdbc访问sqlserver,oracle数据库 DEMO

    1.JDBC访问Oracle数据库 public class Jdbc_Oracle { // 静态代码块,只会执行一次,类似C#静态构造方法 static { try { // 加载数据库驱动一次 ...

  10. c assert 用法

    #include <stdio.h> /* printf */ #include <assert.h> /* assert */ void print_number(int* ...