bzoj 1901: Zju2112 Dynamic Rankings -- 主席树,树状数组,哈希
1901: Zju2112 Dynamic Rankings
Time Limit: 10 Sec Memory Limit: 128 MB
Description
Input
Output
对于每一次询问,你都需要输出他的答案,每一个输出占单独的一行。
Sample Input
3 2 1 4 7
Q 1 4 3
C 2 6
Q 2 5 3
Sample Output
6
HINT
#include<map>
#include<cmath>
#include<queue>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define inf 1000000007
#define ll long long
#define M 10000010
#define N 10010
inline int rd()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int n,m,v[N],A[N],B[N],K[N];
int hs[N<<],ji[N<<],tt,tot=;
int rt[N],sz[M],ls[M],rs[M],cnt;
char s[];
bool q[N];
int hsh(int x)
{
int l=,r=tot,mid,mz;
while(l<=r)
{
mid=l+r>>;
if(hs[mid]<x) l=mid+;
else r=mid-,mz=mid;
}
return mz;
}
void add(int lst,int l,int r,int &p,int x,int w)
{
p=++cnt;
sz[p]=sz[lst]+w;
ls[p]=ls[lst];rs[p]=rs[lst];
if(l==r) return;
int mid=l+r>>;
if(x<=mid) add(ls[lst],l,mid,ls[p],x,w);
else add(rs[lst],mid+,r,rs[p],x,w);
}
int a,b,L[],R[];
int fd(int l,int r,int k)
{
if(l==r) return l;
int mid=l+r>>,sl=,sr=;
for(int i=;i<=a;i++) sl+=sz[ls[L[i]]];
for(int i=;i<=b;i++) sr+=sz[ls[R[i]]];
if(sr-sl>=k)
{
for(int i=;i<=a;i++) L[i]=ls[L[i]];
for(int i=;i<=b;i++) R[i]=ls[R[i]];
return fd(l,mid,k);
}
else
{
for(int i=;i<=a;i++) L[i]=rs[L[i]];
for(int i=;i<=b;i++) R[i]=rs[R[i]];
return fd(mid+,r,k-sr+sl);
}
}
int main()
{
tt=n=rd();m=rd();
for(int i=;i<=n;i++) ji[i]=v[i]=rd();
for(int i=;i<=m;i++)
{
scanf("%s",s);A[i]=rd();B[i]=rd();
if(s[]=='Q') K[i]=rd();
else ji[++tt]=B[i],q[i]=;
}
sort(ji+,ji+tt+);
hs[]=ji[];
for(int i=;i<=tt;i++)
if(ji[i]!=ji[i-]) hs[++tot]=ji[i];
for(int i=,tp;i<=n;i++)
{
tp=hsh(v[i]);
for(int j=i;j<=n;j+=j&(-j))
add(rt[j],,tot,rt[j],tp,);
}
for(int i=,tp;i<=m;i++)
{
if(q[i])
{
tp=hsh(v[A[i]]);
for(int j=A[i];j<=n;j+=j&(-j))
add(rt[j],,tot,rt[j],tp,-);
tp=hsh(B[i]);
for(int j=A[i];j<=n;j+=j&(-j))
add(rt[j],,tot,rt[j],tp,);
v[A[i]]=B[i];
}
else
{
a=b=;
for(int j=A[i]-;j;j-=j&(-j)) L[++a]=rt[j];
for(int j=B[i];j;j-=j&(-j)) R[++b]=rt[j];
printf("%d\n",hs[fd(,tot,K[i])]);
}
}
return ;
}
bzoj 1901: Zju2112 Dynamic Rankings -- 主席树,树状数组,哈希的更多相关文章
- Bzoj 1901: Zju2112 Dynamic Rankings  主席树,可持久,树状数组,离散化
		
1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 6321 Solved: 2628[Su ...
 - BZOJ 1901: Zju2112 Dynamic Rankings[带修改的主席树]【学习笔记】
		
1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 7143 Solved: 2968[Su ...
 - BZOJ 1901: Zju2112 Dynamic Rankings( 树状数组套主席树 )
		
裸的带修改主席树.. 之前用BIT套Splay( http://www.cnblogs.com/JSZX11556/p/4625552.html )A过..但是还是线段树好写...而且快(常数比平衡树 ...
 - Bzoj 1901: Zju2112 Dynamic Rankings  树套树,线段树,平衡树,Treap
		
1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 6471 Solved: 2697[Su ...
 - bzoj 1901: Zju2112 Dynamic Rankings(树套树)
		
1901: Zju2112 Dynamic Rankings 经典的带改动求区间第k小值问题 树套树模板,我是用的线段树套splay实现的,并且用的数组模拟的,所以可能空间略大,bzoj过了,zoj过 ...
 - BZOJ 1901 Zju2112 Dynamic Rankings
		
树阵主席设置树.维护间隔动态K大. .. ZOJ到空间太小,太大,仅仅能到BZOJ上交 1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec Memor ...
 - BZOJ 1901: Zju2112 Dynamic Rankings( BIT 套 BST )
		
BIT 套 splay 其实也是不难...每个 BIT 的结点保存一颗 splay , 询问就二分答案然后判断rank... ------------------------------------- ...
 - BZOJ 1901 Zju2112 Dynamic Rankings ——树状数组套主席树
		
[题目分析] BZOJ这个题目抄的挺霸气. 主席树是第一时间想到的,但是修改又很麻烦. 看了别人的题解,原来还是可以用均摊的思想,用树状数组套主席树. 学到了新的姿势,2333o(* ̄▽ ̄*)ブ [代 ...
 - BZOJ 1901: Zju2112 Dynamic Rankings | 带修改主席树
		
题目: emmmm是个权限题 题解: 带修改主席树的板子题,核心思想是用树状数组维护动态前缀和的性质来支持修改 修改的时候修改类似树状数组一样进行logn个Insert 查询的时候同理,树状数组的方法 ...
 
随机推荐
- Linux移植随笔:终于解决Tslib的问题了【转】
			
转自:http://www.latelee.org/embedded-linux/porting-linux-tslib.html 前段时间让Tslib搞晕头了,原来一切都是版本惹的祸.本文只是一个随 ...
 - gitHub 迁移到gitlab上
			
GitHub 迁移到 GitLab 上 第一步在github上生成 token 地址 https://blog.csdn.net/u014175572/article/details/55510825 ...
 - 阿里云slb+https 实践操作练习
			
如果只是练习按照文档步骤逐步执行即可. 如果是业务需要,只供参考. 有道笔记链接->
 - 二、springboot配置
			
一.启动类 在包根目录下添加启动类,必须包含main方法,再添加Spring Boot启动方法: SpringApplication.run(SampleController.class, args) ...
 - 关于bcb调用动态库,contains invalid OMF record, type 0x21 (possibly COFF)问题
			
今天用C++Builder6.0 调用三方lib文件时,编译的时候出现如下错误: “contains invalid OMF record, type 0x21 (possibly COFF)” 才知 ...
 - IP地址、域名、域名解析系统相关
			
IP地址(Internet Protocol Address) 它来自TCP/IP协议,存在于其中的IP层,用于实现不同计算机之间的通信,类似于门牌号. 设计之处,IP地址是准备给地球上每一台计算机一 ...
 - 【转】http_load压力测试过程和使用方式
			
介绍:http_load以并行复用的方式运行,用以测试web服务器的吞吐量与负载.但是它不同于大多数压力测试工具,它可以以一个单一的进程运行,一般不会把客户机搞死.还可以测试HTTPS类的网站请求. ...
 - matlab随笔(二)
			
circshift 两种形式 :第一种Y = circshift(A,K)就不用说了,将A中的元素向右移动K个位置. 需要注意的是第二种形式:Y = circshift(A,K,dim),这种形式不好 ...
 - CF312B 【Archer】
			
容易算出这人第一次胜利的概率,第二次的,第三次的…… 好像可以无限乘下去 但是这题精度卡到1e-6 不妨设一个eps,当这次胜率小于eps时,就break掉,反正它已经不影响答案了 我设的是eps=1 ...
 - MySql数据库 主从复制/共享 报错
			
从 获取不到 共享主的数据, 错误信息: Waiting for master to send event 解决方案: // 1. 从V表获取PrNo的数据 select * from Vendor_ ...