线段树套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 二逼平衡树的更多相关文章

  1. bzoj3196: Tyvj 1730 二逼平衡树 树套树

    地址:http://www.lydsy.com/JudgeOnline/problem.php?id=3196 题目: 3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec ...

  2. [bzoj3196]Tyvj 1730 二逼平衡树——线段树套平衡树

    题目 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排名 2.查询区间内排名为k的值 3.修改某一位值上的数值 4.查 ...

  3. BZOJ3196: Tyvj 1730 二逼平衡树

    传送门 主席树的常数蜜汁优越,在BZOJ上跑了rnk1. 做法很简单,主席树套BIT. 1-3做法很简单,第四个和第五个做法转换成前两个就行了. //BZOJ 3196 //by Cydiater / ...

  4. 【分块】bzoj3196 Tyvj 1730 二逼平衡树

    分块 或 树套树. 在每个块中维护一个有序表,查询时各种二分,全都是分块的经典操作,就不详细说了. 块的大小定为sqrt(n*log2(n))比较快. #include<cstdio> # ...

  5. [bzoj3196][Tyvj 1730][二逼平衡树] (线段树套treap)

    Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排名 2.查询区间内排名为k的值 3.修改某一位值上的数值 4.查询k在 ...

  6. 【带修莫队】【权值分块】bzoj3196 Tyvj 1730 二逼平衡树

    这题用了三种算法写: 分块+二分:O(n*sqrt(n*log(n)) 函数式权值分块:O(n*sqrt(n)) 带修莫队+权值分块:O(n5/3) 结果……复杂度越高的实际上跑得越快……最后这个竟然 ...

  7. 【函数式权值分块】【分块】bzoj3196 Tyvj 1730 二逼平衡树

    #include<cstdio> #include<cmath> #include<algorithm> using namespace std; #define ...

  8. bzoj 3196 Tyvj 1730 二逼平衡树(线段树套名次树)

    3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1807  Solved: 772[Submit][Stat ...

  9. bzoj 3196/ Tyvj 1730 二逼平衡树 (线段树套平衡树)

    3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description ...

随机推荐

  1. Eclipse 关联项目的源码

    Eclipse 关联项目的源码 1.jdk源码的关联: 一般jdk自带的类,显示其源码的方式: 用jdk自带的src.zip吧:我的JDK目录是:D:\Java\jdk1.6.0_10 , JRE目录 ...

  2. spring 异常记录

    1.异常: java.lang.IllegalArgumentException: No converter found for return value of type: class java.ut ...

  3. PHP实现CSV大文件数据导入到MYSQL数据库

    <?php $db_host="192.168.1.10"; $db_user="root"; $db_psw="11111"; $d ...

  4. 利用Unity制作“表”

    一枚小菜鸟   目前没发现在Unity有其他路径制作类似于c# WinForm中的表:但是利用Unity自带的UGUI,制作了一张"伪表",具体方案如下: 效果图如下: 步骤: 1 ...

  5. Java调用第三方dll文件的使用方法 System.load()或System.loadLibrary()

    Java调用第三方dll文件的使用方法 public class OtherAdapter { static { //System.loadLibrary("Connector") ...

  6. SharePreference 工具类封装

    import java.util.List;import java.util.Map;import java.util.Set;import com.alibaba.fastjson.JSON;imp ...

  7. 使用JS脚本获取url中的参数

    第一种方式:使用分隔符及循环查找function getQueryString(name) { // 如果链接没有参数,或者链接中不存在我们要获取的参数,直接返回空 if(location.href. ...

  8. 转:亿级Web系统的高容错性实践(好博文)

    亿级Web系统的高容错性实践 亿级Web系统的高容错性实践 背景介绍 大概三年前,我在腾讯负责的活动运营系统,因为业务流量规模的数倍增长,系统出现了各种各样的异常,当时,作为开发的我,7*24小时地没 ...

  9. Apache htpasswd命令用法详解

    一. 基础 htpasswd建立和更新存储用户名.密码的文本文件, 用于对HTTP用户的basic认证. # /usr/local/apache/bin/htpasswd –help Usage: h ...

  10. Modern C++ CHAPTER 2(读书笔记)

    CHAPTER 2 Recipe 2-1. Initializing Variables Recipe 2-2. Initializing Objects with Initializer Lists ...