【BZOJ3196】Tyvj 1730 二逼平衡树
Description
您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:
1.查询k在区间内的排名
2.查询区间内排名为k的值
3.修改某一位值上的数值
4.查询k在区间内的前驱(前驱定义为小于x,且最大的数)
5.查询k在区间内的后继(后继定义为大于x,且最小的数)
Input
第一行两个数 n,m 表示长度为n的有序序列和m个操作
第二行有n个数,表示有序序列
下面有m行,opt表示操作标号
若opt=1 则为操作1,之后有三个数l,r,k 表示查询k在区间[l,r]的排名
若opt=2 则为操作2,之后有三个数l,r,k 表示查询区间[l,r]内排名为k的数
若opt=3 则为操作3,之后有两个数pos,k 表示将pos位置的数修改为k
若opt=4 则为操作4,之后有三个数l,r,k 表示查询区间[l,r]内k的前驱
若opt=5 则为操作5,之后有三个数l,r,k 表示查询区间[l,r]内k的后继
Output
对于操作1,2,4,5各输出一行,表示查询结果
Sample Input
4 2 2 1 9 4 0 1 1
2 1 4 3
3 4 10
2 1 4 3
1 2 5 9
4 3 9 5
5 2 8 5
Sample Output
4
3
4
9
HINT
1.n和m的数据范围:n,m<=50000
2.序列中每个数的数据范围:[0,1e8]
#include<cstdio>
#include<cstdlib>
#include<iostream>
using namespace std;
const int inf=,N=,M=;
int num[N],rnd[N],size[N],ls[N],rs[N],root[M],w[N],a[M];
int sz,n,m,opt,l,r;
void updata(int k){size[k]=size[ls[k]]+size[rs[k]]+w[k];}
void rturn(int &k){int t=ls[k];ls[k]=rs[t];rs[t]=k;size[t]=size[k];updata(k);k=t;}
void lturn(int &k){int t=rs[k];rs[k]=ls[t];ls[t]=k;size[t]=size[k];updata(k);k=t;}
void insert(int &k,int x){
if (!k){
k=++sz;num[k]=x;rnd[k]=rand();size[k]=w[k]=;return;
}
size[k]++;
if (x==num[k]) {w[k]++;return;}
if (x<num[k]) {insert(ls[k],x);if (rnd[ls[k]]<rnd[k]) rturn(k);}
if (x>num[k]) {insert(rs[k],x);if (rnd[rs[k]]<rnd[k]) lturn(k);}
} void del(int &k,int x){
if (!k) return;
if (num[k]==x){
if (w[k]>){w[k]--;size[k]--;return;}//就是这里,不知道为什么不是在前面直接size[k]--
if(ls[k]*rs[k]==){k=ls[k]+rs[k]; return;}
if (rnd[ls[k]]<rnd[rs[k]])rturn(k),del(k,x);
else lturn(k),del(k,x);
}
else if (num[k]>x) del(ls[k],x),size[k]--;else del(rs[k],x),size[k]--;
} void change(int pos,int x){
int k=,l=,r=n,mid=(l+r)>>;
while (l!=r){
mid=(l+r)>>;
del(root[k],a[pos]);
insert(root[k],x);
if (mid>=pos)k=k<<,r=mid;
else k=k<<|,l=mid+;
}
mid=(l+r)>>;
del(root[k],a[pos]);
insert(root[k],x);
} int solve_rank(int k,int x){
if (!k) return ;
int l=ls[k],r=rs[k];
if (num[k]==x) return size[l];
else if (num[k]>x) return solve_rank(l,x);
else return solve_rank(r,x)+size[l]+w[k];
} int get_rank(int k,int l,int r,int L,int R,int x){
if (l==L&&r==R) return (solve_rank(root[k],x));
int mid=(l+r)>>;
if (R<=mid) return get_rank(k<<,l,mid,L,R,x);
else if (L>mid) return get_rank(k<<|,mid+,r,L,R,x);
else return get_rank(k<<,l,mid,L,mid,x)+get_rank(k<<|,mid+,r,mid+,R,x);
} void build(int x,int y){
int l=,r=n,k=,mid=(l+r)>>;
while(l!=r){
insert(root[k],y);
if (mid>=x) r=mid,mid=(l+r)>>,k=k<<;
else l=mid+,mid=(l+r)>>,k=k<<|;
}
insert(root[k],y);
} int get_num(int x,int y,int z){
int l=,r=inf,ans;
while (l<=r){
int mid=(l+r)>>;
int tmp=get_rank(,,n,x,y,mid);
if (tmp<=z) ans=mid,l=mid+;//因为有重复的数字,tmp偏小
else r=mid-;
}
return ans;
} int solve_pre(int k,int x){
int l=ls[k],r=rs[k];
if (!k) return ;
if (num[k]<x) return max(num[k],solve_pre(r,x));//这里不要顺手打上=
else return solve_pre(l,x);
} int get_pre(int k,int l,int r,int L,int R,int x){
if (l==L&&r==R) return (solve_pre(root[k],x));
int mid=(l+r)>>;
if (R<=mid) return get_pre(k<<,l,mid,L,R,x);
else if (L>mid) return get_pre(k<<|,mid+,r,L,R,x);
else return max(get_pre(k<<,l,mid,L,mid,x),get_pre(k<<|,mid+,r,mid+,R,x));
} int solve_after(int k,int x){
int l=ls[k],r=rs[k];
if (!k) return inf;
if (num[k]>x) return min(num[k],solve_after(l,x));//这里不要顺手打上=*2
else return solve_after(r,x);
} int get_after(int k,int l,int r,int L,int R,int x){
if (l==L&&r==R) return (solve_after(root[k],x));
int mid=(l+r)>>;
if (R<=mid) return get_after(k<<,l,mid,L,R,x);
else if (L>mid) return get_after(k<<|,mid+,r,L,R,x);
else return min(get_after(k<<|,mid+,r,mid+,R,x),get_after(k<<,l,mid,L,mid,x));
} int main(){
freopen("sj.txt","r",stdin);
freopen("me.txt","w",stdout);
int k;
scanf("%d%d",&n,&m);
for (int i=;i<=n;i++){scanf("%d",&a[i]);build(i,a[i]);}
for (int i=;i<=m;i++){
scanf("%d%d%d",&opt,&l,&r);
if (opt!=)scanf("%d",&k);
switch(opt){
case :printf("%d\n",get_rank(,,n,l,r,k)+);break;
case :printf("%d\n",get_num(l,r,k-));break;
case :change(l,r);a[l]=r;break;
case :printf("%d\n",get_pre(,,n,l,r,k));break;
case :printf("%d\n",get_after(,,n,l,r,k));break;
}
}
}
【BZOJ3196】Tyvj 1730 二逼平衡树的更多相关文章
- bzoj3196: Tyvj 1730 二逼平衡树 树套树
地址:http://www.lydsy.com/JudgeOnline/problem.php?id=3196 题目: 3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec ...
- 【线段树套平衡树】【pb_ds】bzoj3196 Tyvj 1730 二逼平衡树
线段树套pb_ds里的平衡树,在洛谷OJ上测试,后三个测试点TLE #include<cstdio> #include<algorithm> #include<ext/p ...
- [bzoj3196]Tyvj 1730 二逼平衡树——线段树套平衡树
题目 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排名 2.查询区间内排名为k的值 3.修改某一位值上的数值 4.查 ...
- BZOJ3196: Tyvj 1730 二逼平衡树
传送门 主席树的常数蜜汁优越,在BZOJ上跑了rnk1. 做法很简单,主席树套BIT. 1-3做法很简单,第四个和第五个做法转换成前两个就行了. //BZOJ 3196 //by Cydiater / ...
- [bzoj3196][Tyvj 1730][二逼平衡树] (线段树套treap)
Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排名 2.查询区间内排名为k的值 3.修改某一位值上的数值 4.查询k在 ...
- 【分块】bzoj3196 Tyvj 1730 二逼平衡树
分块 或 树套树. 在每个块中维护一个有序表,查询时各种二分,全都是分块的经典操作,就不详细说了. 块的大小定为sqrt(n*log2(n))比较快. #include<cstdio> # ...
- 【带修莫队】【权值分块】bzoj3196 Tyvj 1730 二逼平衡树
这题用了三种算法写: 分块+二分:O(n*sqrt(n*log(n)) 函数式权值分块:O(n*sqrt(n)) 带修莫队+权值分块:O(n5/3) 结果……复杂度越高的实际上跑得越快……最后这个竟然 ...
- 【函数式权值分块】【分块】bzoj3196 Tyvj 1730 二逼平衡树
#include<cstdio> #include<cmath> #include<algorithm> using namespace std; #define ...
- bzoj 3196 Tyvj 1730 二逼平衡树(线段树套名次树)
3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1807 Solved: 772[Submit][Stat ...
- BZOJ 3196: Tyvj 1730 二逼平衡树( 树套树 )
这道题做法应该很多吧.... 我用了线段树套treap.... -------------------------------------------------------------------- ...
随机推荐
- poj 2492 并查集
思路:当a,b的根节点find(a)与find(b)不同时,就直接将这两个数连接起来.由于每个树的根节点的kind值一定为0,所以,对于a,b的kind值相同,我们就讲其中一个根的kind值变为1,当 ...
- Font Awesome图标字体库(2015年05月25日)
Font Awesome是一款非常棒的字体图标工具,给个地址,具体的自已慢慢去体会,只能帮你到这儿了...... http://fortawesome.github.io/Font-Awesome/ ...
- HTML5新特性之WebNotifications
Web Notifications是HTML5中一个令人欣喜的新特性,它支持开发者配置和显示桌面通知,为用户提供更好的体验,最令人称赞的是,即使用户忙于其他工作时也可以收到来自页面的消息通知,例如一个 ...
- 使用subst创建虚拟磁盘及设置分区卷标
最近项目中要研究在"计算机"中添加虚拟磁盘,能够访问某远端目录,同时还要在资源管理器中可以看到创建的虚拟磁盘.关于虚拟磁盘,有几种方式: (1)映射网络磁盘:通过映射网络驱动器,可 ...
- phpwind wap功能添加百度wap统计
百度推出wap统计功能后,及大的方便了个站长对wap网站的统计.PHPWIND自带的wap功能虽然说功能不是太强,但是对百度来说是非常友好的,如果再进一不优化一下页面模板,这样会对网友访问网站信息有非 ...
- Sublime Text 3下 Emmet 使用小技巧
Emmet常用技巧:(输入下面简写,按Tab键可触发效果) 生成 HTML 文档初始结构 html:5 或者 ! 生成 HTML5 结构 ...
- Xcode7网络问题
更新Xcode7以后运行模拟器,控制台打印:Application Transport Security has blocked a cleartext HTTP (http://) resource ...
- OC3_歌词解析
// // LrcManager.h // OC3_歌词解析 // // Created by zhangxueming on 15/6/15. // Copyright (c) 2015年 zhan ...
- 高性能CSS(三)
CSS选择器对性能的影响源于浏览器匹配选择器和文档元素时所消耗的时间,所以优化选择器的原则是应尽量避免需要消耗更多匹配时间的选择器.而在这之前我们需要了解CSS选择器匹配的机制,如例子的子选择器规则: ...
- vs2010创建COM以及调用
1,创建COM组件 2,调用COM 3,MFC调用COM