zoj2112&&bzoj1901
题解:
可修改的主席树
一开始,我就按照最暴力的方法,空间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的更多相关文章
- [主席树]ZOJ2112 && BZOJ1901 Dynamic Rankings
题意:n个数,q个询问 (n<=50000, q<=10000) Q x y z 代表询问[x, y]区间里的第z小的数 C x y 代表将(从左往右数)第x个数变成y 上篇介绍了在 ...
- ZOJ2112 BZOJ1901 Dynamic Rankings 树套树 带修改的区间第k小
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2112 树套树,线段树套splay或者主席树套树状数组,我抄了一下hzwer ...
- bzoj1901&zoj2112&cogs257 Dynamic Rankings(动态排名系统)
bzoj1901&zoj2112&cogs257 Dynamic Rankings(动态排名系统) cogs zoj bzoj-权限 题解 bzoj和zoj都是骗访问量的233,我没有 ...
- BZOJ1901 ZOJ2112 线段树+treap (线段树套线段树)
BZOJ1901: 线段树套线段树做法: (外层线段树 里层动态开节点的权值线段树) 有一个小小的trick 可以省掉二分变成nlog^2n的 就是把查询的区间都取出来- logn个一起走- 2016 ...
- [bzoj1901][zoj2112][Dynamic Rankings] (整体二分+树状数组 or 动态开点线段树 or 主席树)
Dynamic Rankings Time Limit: 10 Seconds Memory Limit: 32768 KB The Company Dynamic Rankings has ...
- 可修改的区间第K大 BZOJ1901 ZOJ2112
http://blog.csdn.net/u014492306/article/details/47981315 //变相离线做法 离散化缩小区间范围,做两大个线段树,第一个就是普通的持久化树,有个前 ...
- 【树状数组套权值线段树】bzoj1901 Zju2112 Dynamic Rankings
谁再管这玩意叫树状数组套主席树我跟谁急 明明就是树状数组的每个结点维护一棵动态开结点的权值线段树而已 好吧,其实只有一个指针,指向该结点的权值线段树的当前结点 每次查询之前,要让指针指向根结点 不同结 ...
- [BZOJ1901]Zju2112 Dynamic Rankings
[BZOJ1901]Zju2112 Dynamic Rankings 试题描述 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i ...
- zoj2112
题目:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2112 经典的动态区间第K大. 用树状数组套线段树. 对原数组建一个树 ...
随机推荐
- 【转】各种消息下wParam及lParam值的含义
转载自:http://bbs.fishc.com/forum.php?mod=viewthread&tid=52668#lastpost 01.WM_PAINT消息 LOWORD(lParam ...
- TCP 的连接建立:采用三报文握手
- github客户端上传代码
在window下安装github客户端上传代码 第一步:创建Github新账户 第二步:新建仓库 第三步:安装Github shell程序,地址:http://windows.github.com/ ...
- redis.conf 配置 详解 中文 2.8
# redis version 2.8.19 # 1k => 1000 bytes# 1kb => 1024 bytes# 1m => 1000000 bytes# 1m ...
- 将DevExpress.Utils.ImageCollection变量的image导出
private void tspBtnExportExcel_Click(object sender, EventArgs e) { //暂时用来导出图片 string filePath = Syst ...
- AtCoder square869120 Contest #3 F sushi
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- Cocos2d-x学习笔记(三)main方法
0. UNREFERENCED_PARAMETER(X)避免编译器关于未引用参数的警告. 下边代码用于屏蔽单个函数的警告: #pragma warning( push ) #pragma warnin ...
- shell while 语句
普通循环格式: while condition do command done 例子一 #!/bin/bash )) do echo $int let "int++" done 结 ...
- Linux 下的profile
# /etc/profile # System wide environment and startup programs, for login setup# Functions and aliase ...
- 机器学习 Matplotlib库入门
2017-07-21 15:22:05 Matplotlib库是一个优秀的python的数据可视化的第三方类库,其中的pyplot支持了类似matlab的图像输出操作.matplotlib.pyplo ...