传送门

就是普通平衡树,可以拿来练非旋treap" role="presentation" style="position: relative;">treaptreap的板子。

贴个代码:

#include<bits/stdc++.h>
#define N 300005
using namespace std;
typedef pair<int,int> res;
int n;
inline int read(){
    int ans=0;
    char ch=getchar();
    while(!isdigit(ch))ch=getchar();
    while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
    return ans;
}
struct Treap{
    int son[N][2],root,cnt,siz[N],rd[N],val[N];
    inline int build(int v){siz[++cnt]=1,val[cnt]=v,rd[cnt]=rand(),son[cnt][0]=son[cnt][1]=0;return cnt;}
    inline void pushup(int p){siz[p]=siz[son[p][0]]+siz[son[p][1]]+1;}
    inline int merge(int a,int b){
        if(!a||!b)return a+b;
        if(rd[a]<rd[b]){son[a][1]=merge(son[a][1],b),pushup(a);return a;}
        son[b][0]=merge(a,son[b][0]),pushup(b);return b;
    }
    inline res split(int p,int k){
        if(!p)return res(0,0);
        res tmp,ans;
        if(siz[son[p][0]]>=k){tmp=split(son[p][0],k),son[p][0]=tmp.second,pushup(p),ans.first=tmp.first,ans.second=p;return ans;}
        tmp=split(son[p][1],k-siz[son[p][0]]-1),son[p][1]=tmp.first,pushup(p),ans.first=p,ans.second=tmp.second;return ans;
    }
    inline int rank(int p,int v){
        if(!p)return 0;
        if(val[p]>v)return rank(son[p][0],v);
        return rank(son[p][1],v)+siz[son[p][0]]+1;
    }
    inline int kth(int k){
        res x=split(root,k),y=split(x.first,k-1);
        root=merge(merge(y.first,y.second),x.second);
        return val[y.second];
    }
    inline int find(int p,int v){
        if(!p)return 0;
        if(val[p]>=v)return find(son[p][0],v);
        return find(son[p][1],v)+siz[son[p][0]]+1;
    }
    inline void ins(int v){
        int k=rank(root,v);
        res x=split(root,k);
        int p=build(v);
        root=merge(merge(x.first,p),x.second);
    }
    inline void del(int v){
        int k=rank(root,v);
        res x=split(root,k);
        root=merge(split(x.first,k-1).first,x.second);
    }
    inline int pre(int p,int v){
        if(!p)return -0x3f3f3f3f;
        if(val[p]<v)return max(val[p],pre(son[p][1],v));
        return pre(son[p][0],v);
    }
    inline int suf(int p,int v){
        if(!p)return 0x3f3f3f3f;
        if(val[p]>v)return min(val[p],suf(son[p][0],v));
        return suf(son[p][1],v);
    }
}T;
int main(){
    srand(time(NULL));
    n=read();
    while(n--){
        int op=read(),x=read();
        switch(op){
            case 0:{T.ins(x);break;}
            case 1:{T.del(x);break;}
            case 2:{printf("%d\n",T.kth(x));break;}
            case 3:{printf("%d\n",T.find(T.root,x));break;}
            case 4:{int tmp=T.pre(T.root,x);printf("%d\n",tmp==-0x3f3f3f3f?-1:tmp);break;}
            default:{int tmp=T.suf(T.root,x);printf("%d\n",tmp==0x3f3f3f3f?-1:tmp);break;}
        }
    }
    return 0;
}

2018.07.24 loj#107. 维护全序集(非旋treap)的更多相关文章

  1. LOJ#107. 维护全序集(FHQ Treap)

    题面 传送门 题解 板子,没啥好说的 //minamoto #include<bits/stdc++.h> #define R register #define inline __inli ...

  2. loj #107. 维护全序集

    #107. 维护全序集 题目描述 这是一道模板题,其数据比「普通平衡树」更强. 如未特别说明,以下所有数据均为整数. 维护一个多重集 S SS ,初始为空,有以下几种操作: 把 x xx 加入 S S ...

  3. China Cloud Computing Conference(2018.07.24)

    时间:2018.07.24地点:北京国家会议中心

  4. 2018.07.06 BZOJ 1588: HNOI2002营业额统计(非旋treap)

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MB Description 营业额统计 Tiger最近被公司升任为营业部经理,他上 ...

  5. 2018.08.06 bzoj1500: [NOI2005]维修数列(非旋treap)

    传送门 平衡树好题. 我仍然是用的fhqtreap,感觉速度还行. 维护也比线段树splay什么的写起来简单. %%%非旋treap大法好. 代码: #include<bits/stdc++.h ...

  6. 2018.08.27 rollcall(非旋treap)

    描述 初始有一个空集,依次插入N个数Ai.有M次询问Bj,表示询问第Bj个数加入集合后的排名为j的数是多少 输入 第一行是两个整数N,M 接下来一行有N个整数,Ai 接下来一行有M个整数Bj,保证数据 ...

  7. 2018.08.05 bzoj3223: Tyvj 1729 文艺平衡树(非旋treap)

    传送门 经典的平衡树问题,之前已经用splay写过一次了,今天我突发奇想,写了一发非旋treap的版本,发现挺好写的(虽然跑不过splay). 代码: #include<bits/stdc++. ...

  8. 非旋 treap 结构体数组版(无指针)详解,有图有真相

    非旋  $treap$ (FHQ treap)的简单入门 前置技能 建议在掌握普通 treap 以及 左偏堆(也就是可并堆)食用本blog 原理 以随机数维护平衡,使树高期望为logn级别, FHQ  ...

  9. [模板] 平衡树: Splay, 非旋Treap, 替罪羊树

    简介 二叉搜索树, 可以维护一个集合/序列, 同时维护节点的 \(size\), 因此可以支持 insert(v), delete(v), kth(p,k), rank(v)等操作. 另外, prev ...

随机推荐

  1. Webservice 返回数据集 DataSet 及Android显示数据集LiveBindings

    一.服务端 New TSoapDataModule 添加控件 TDataSetProvider,TClientDataSet,TADOQuery,TADOConnection 添加方法 functio ...

  2. setlocal 与 变量延迟

    setlocal 与 变量延迟 本条内容引用[英雄出品]的批处理教程: 要想进阶,变量延迟是必过的一关!所以这一部分希望你能认真看. 为了更好的说明问题,我们先引入一个例子.例1: @echo off ...

  3. vue 项目部署后 刷新一下 页面找不到 解决

    1.修改配置router的参数  (效果不好) 2. (不能解决 出现403) 后端配置例子 Apache <IfModule mod_rewrite.c> RewriteEngine O ...

  4. servlet类

    一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun公司在其API中提供了一个servlet接口,用户若想用发一个动态web资源(即开发一个Java程序向 ...

  5. MVC3 发布到IIS 7.5

    1.应用程序池采用集成模式(建议),.NET Framework版本为: .NET Framework4.0.30319. 2.确保ASP.NET MVC3已安装好,然后检查站点的处理程序映射,看是否 ...

  6. t检验,T Test (Student’s T-Test)

    1.什么是T test? t-test:比较数据的均值,告诉你这两者之间是否相同,并给出这种不同的显著性(即是否是因为偶然导致的不同) The t test (also called Student’ ...

  7. 视图的URL配置,找不到我设置的第一个Page

    问题:视图的URL配置,找不到我设置的第一个Page 我的代码如下: 结果访问/test/时说找不到这个page   原因:patterns方法的参数有两个,一个是prefix,一个是参数元祖,详见下 ...

  8. 执行js,通过js显示隐藏的输入框,或者给input赋值

    在测试过程中,有些输入框是隐藏的,如果直接对他进行赋值,会找不到这个输入框,从而导致脚本运行失败. 例如下面的这个密码输入框: 登录密码输入框分为两个input,下面的是提示的,上面的才是真正存下来的 ...

  9. Spring的属性注入, byName和byType还有注入List属性

    昨天花了一晚上的时间又仔细研究了一下Spring的属性注入, 一个新的方法: 自动装载和autowire, 不过因为又想起来老师说不常用, 感觉这一晚上的时间有点亏, 还是自己太愚钝了, 反应太慢 先 ...

  10. The Closest M Points

    The Closest M Points http://acm.hdu.edu.cn/showproblem.php?pid=4347 参考博客:https://blog.csdn.net/acdre ...