【线段树套平衡树】【pb_ds】bzoj3196 Tyvj 1730 二逼平衡树
线段树套pb_ds里的平衡树,在洛谷OJ上测试,后三个测试点TLE
#include<cstdio>
#include<algorithm>
#include<ext/pb_ds/assoc_container.hpp>
#include<ext/pb_ds/tree_policy.hpp>
#define N 50010
#define INF 2147483647
using namespace std;
using namespace __gnu_pbds;
typedef pair<int,int> Point;
typedef tree<Point,null_type,less<Point>,rb_tree_tag,tree_order_statistics_node_update> rb_tree;
typedef rb_tree::iterator ITER;
rb_tree T[N<<2];
int a[N],tags[N],tag,n,m;
void buildtree(int rt,int l,int r)
{
if(l==r)
{
T[rt].insert(Point(a[l],l));
return;
}
int m=(l+r>>1);
buildtree(rt<<1,l,m);
buildtree(rt<<1|1,m+1,r);
T[rt]=T[rt<<1];
for(ITER it=T[rt<<1|1].begin();it!=T[rt<<1|1].end();++it)
T[rt].insert(*it);
}
int Rank(int v,int TAG,int ql,int qr,int rt,int l,int r)
{
if(ql<=l&&r<=qr)
return T[rt].order_of_key(Point(v,TAG));
int m=(l+r>>1),res=0;
if(ql<=m) res+=Rank(v,TAG,ql,qr,rt<<1,l,m);
if(m<qr) res+=Rank(v,TAG,ql,qr,rt<<1|1,m+1,r);
return res;
}
int Pre(int v,int ql,int qr,int rt,int l,int r)
{
if(ql<=l&&r<=qr)
{
ITER it=T[rt].lower_bound(Point(v,0));
if(it==T[rt].begin()) return -INF;
--it;
return (*it).first;
}
int m=(l+r>>1),res=-INF;
if(ql<=m) res=max(res,Pre(v,ql,qr,rt<<1,l,m));
if(m<qr) res=max(res,Pre(v,ql,qr,rt<<1|1,m+1,r));
return res;
}
int Nex(int v,int ql,int qr,int rt,int l,int r)
{
if(ql<=l&&r<=qr)
{
ITER it=T[rt].upper_bound(Point(v,INF));
if(it==T[rt].end())
return INF;
return (*it).first;
}
int m=(l+r>>1),res=INF;
if(ql<=m) res=min(res,Nex(v,ql,qr,rt<<1,l,m));
if(m<qr) res=min(res,Nex(v,ql,qr,rt<<1|1,m+1,r));
return res;
}
void Update(int p,int v,int rt,int l,int r)
{
T[rt].erase(Point(a[p],tags[p]));
T[rt].insert(Point(v,tag));
if(l==r) return;
int m=(l+r>>1);
if(p<=m) Update(p,v,rt<<1,l,m);
else Update(p,v,rt<<1|1,m+1,r);
}
int Kth(int K,int ql,int qr)
{
int l=0,r=100000000;
while(l<r)
{
int m=(l+r>>1);
if(Rank(m,INF,ql,qr,1,1,n)>=K)
r=m;
else
l=m+1;
}
return l;
}
int main()
{
// freopen("bzoj3196.in","r",stdin);
int op,x,y,z;
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i)
{
scanf("%d",&a[i]);
tags[i]=i;
}
tag=n;
buildtree(1,1,n);
// for(int i=1;i<=n*4;++i)
// printf("%d ",(*T[i].begin()).second);
// puts("");
for(;m;--m)
{
scanf("%d%d%d",&op,&x,&y);
if(op==1)
{
scanf("%d",&z);
printf("%d\n",Rank(z,0,x,y,1,1,n)+1);
}
else if(op==2)
{
scanf("%d",&z);
printf("%d\n",Kth(z,x,y));
}
else if(op==3)
{
++tag;
Update(x,y,1,1,n);
a[x]=y;
tags[x]=tag;
}
else if(op==4)
{
scanf("%d",&z);
printf("%d\n",Pre(z,x,y,1,1,n));
}
else
{
scanf("%d",&z);
printf("%d\n",Nex(z,x,y,1,1,n));
}
}
return 0;
}
【线段树套平衡树】【pb_ds】bzoj3196 Tyvj 1730 二逼平衡树的更多相关文章
- bzoj3196: Tyvj 1730 二逼平衡树 树套树
地址:http://www.lydsy.com/JudgeOnline/problem.php?id=3196 题目: 3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec ...
- [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 二逼平衡树
分块 或 树套树. 在每个块中维护一个有序表,查询时各种二分,全都是分块的经典操作,就不详细说了. 块的大小定为sqrt(n*log2(n))比较快. #include<cstdio> # ...
- [bzoj3196][Tyvj 1730][二逼平衡树] (线段树套treap)
Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排名 2.查询区间内排名为k的值 3.修改某一位值上的数值 4.查询k在 ...
- 【带修莫队】【权值分块】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 二逼平衡树 (线段树套平衡树)
3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description ...
随机推荐
- EntityFramework+MySql 笔记1
最近需要使用mysql ,而之前用惯了EF,所以就尝试EntityFramework+MySql的方案. 首先上网搜了一大通资料后,这样开始: 安装mysql,我用的版本是5.6.25 ( windo ...
- 通过反射绑定事件_Office Visio
花了好几个小时才Try出来,记录一下: //反射获取Visio.Application,此处没有判断是否有安装Visio mVisioType = System.Type.Get ...
- 网络TCp数据的传输设计(黏包处理)
//1.该片为引用别人的文章:http://www.cnblogs.com/alon/archive/2009/04/16/1437599.html 解决TCP网络传输"粘包"问题 ...
- Linux 下的dd命令使用详解(摘录)
一.dd命令的解释 dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换. 注意:指定数字的地方若以下列字符结尾,则乘以相应的数字:b=512:c=1:k=1024:w=2 参数注释: 1. ...
- http2协议翻译(转)
超文本传输协议版本 2 IETF HTTP2草案(draft-ietf-httpbis-http2-13) 摘要 本规范描述了一种优化的超文本传输协议(HTTP).HTTP/2通过引进报头字段压缩以及 ...
- maxiang.io css
/**设置你自己的CSS.例如:h1 { border-bottom: 1px solid #ccc; line-height:1.6;}body { background:#FDFFD0} **/p ...
- JS中变量名作为if条件的 true/flase
在Javascript中,可以直接将变量名放到if条件中, var a;//甚至不定义 if (a){ //... } 以下情况被认为是flase: 1.''空的字符串 2.数字0 3.对象null ...
- 查看oracle表中列的数据类型
一. SQLPLUS中,直接用 DESC[ribe] tablename 即可. 二.在外部应用程序调用查看ORACLE中的表结构时,只能用下面的语句代替: 1.看字段名与数据类型 select * ...
- 07-JAVA继承与接口
动手动脑: 源程序: public class FuGai { public static void main(String[] args) { // TODO Auto-generated meth ...
- Nginx+tomcat负载均衡时静态页面报404
百度到的问题解决BLOG http://os.51cto.com/art/201204/326843.htm nginx+2台tomcat负载均衡,应用程序已部署,单独访问tomcat时,可以访问到所 ...