之前写treap的传送门
之前写的那个太毒瘤了,这次放一个更毒瘤的指针版上来

#include<cstdio>
#include<iostream>
#define rg register
#define ci const int
#define cl const long long

typedef long long int ll;
typedef unsigned int uit;

template <typename T>
inline void qr(T &x) {
    rg char ch=getchar(),lst=' ';
    while((ch > '9') || (ch < '0')) lst=ch,ch=getchar();
    while((ch >= '0') && (ch <= '9')) x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
    if(lst == '-') x=-x;
}

namespace IO {
    char buf[120];
}

template <typename T>
inline void qw(T x,const char aft,const bool pt) {
    if(x < 0) {x=-x,putchar('-');}
    rg int top=0;
    do {IO::buf[++top]=x%10+'0';} while(x/=10);
    while(top) putchar(IO::buf[top--]);
    if(pt) putchar(aft);
}

template <typename T>
inline T mmax(const T a,const T b) {return a > b ? a : b;}
template <typename T>
inline T mmin(const T a,const T b) {return a < b ? a : b;}
template <typename T>
inline T mabs(const T a) {return a < 0 ? -a : a;}

template <typename T>
inline void mswap(T &_a,T &_b) {
    T _temp=_a;_a=_b;_b=_temp;
}

const int maxn = 100010;
const int INF = 20000000;

inline uit GetRandom(uit &x) {
    x^=x<<5;
    x^=x>>7;
    x^=x<<17;
    return x;
}

struct Treap {
    Treap *ls,*rs,*fa;
    int v,sz,sm,key;
    Treap() {ls=rs=fa=NULL;key=v=sz=sm=0;}
    inline int GetRelation(ci _v) {
        if(this->v == _v) return 0;
        else if(this->v > _v) return -1;
        else return 1;
    }
    inline void ChangeV(ci _v) {
        this->sm+=_v;this->sz+=_v;
    }
    inline bool NeedTurn(Treap *_son) {
        return this->key > _son->key;
    }
    inline void update() {
        this->sz=this->sm;//printf("QwQ%d ",this->sz);
        if(this->ls) this->sz+=this->ls->sz;//printf("(%d %d)",this->ls->v,this->ls->sz);
        if(this->rs) this->sz+=this->rs->sz;
    //  printf("(%d %d)\n",this->v,this->sz);
    }
    inline bool IsLeftSon() {
        return this->fa->ls == this;
    }
    inline void RTurn() {
        Treap *newrt=this->ls;
        this->ls=newrt->rs;
        if(this->ls) this->ls->fa=this;
        if(this->IsLeftSon()) this->fa->ls=newrt;
        else this->fa->rs=newrt;
        newrt->fa=this->fa;
        this->fa=newrt;
        newrt->rs=this;
        this->update();newrt->update();
    }
    inline void LTurn() {
        Treap *newrt=this->rs;
        this->rs=newrt->ls;
        if(this->rs) this->rs->fa=this;
        if(this->IsLeftSon()) this->fa->ls=newrt;
        else this->fa->rs=newrt;
        newrt->fa=this->fa;
        this->fa=newrt;
        newrt->ls=this;
        this->update();newrt->update();
    }
    void dltit() {
        this->key=INF;
        while((this->ls) || (this->rs)) {
            if(this->ls) {
                if(this->rs) {
                    if(this->ls->key < this->rs->key) this->RTurn();
                    else this->LTurn();
                }
                else this->RTurn();
            }
            else this->LTurn();
        }
        for(Treap *i=this->fa;i->fa;i=i->fa) {
            i->update();
        }
        if(this->IsLeftSon()) this->fa->ls=NULL;
        else this->fa->rs=NULL;
        *this=Treap();
    }
};
Treap *pool[maxn],*rot,qwq[maxn];
int top;

int n;
uit sed=19620718;

void buildroot();
void buildpool();
void add(Treap*,ci);
void dlt(Treap*,ci);
int askrnk(Treap*,ci);
int asknum(Treap*,ci);
int askpre(Treap*,ci);
int askpro(Treap*,ci);
void LinkNew(Treap*,ci,ci);

int main() {
    freopen("1.in","r",stdin);
    freopen("1.out","w",stdout);
    qr(n);
    buildpool();
    buildroot();
    int a,b;
    while(n--) {
        a=b=0;qr(a);qr(b);
        if(a == 1) add(rot,b);
        else if(a == 2) dlt(rot,b);
        else if(a == 3) qw(askrnk(rot,b),'\n',true);
        else if(a == 4) qw(asknum(rot,b),'\n',true);
        else if(a == 5) qw(askpre(rot,b),'\n',true);
        else if(a == 6) qw(askpro(rot,b),'\n',true);
    }
    return 0;
}

void buildpool() {
    for(rg int i=0;i<maxn;++i) pool[i]=qwq+i;
    top=maxn-1;
}

void buildroot() {
    rot=pool[top--];
    rot->key=-INF;rot->v=INF;rot->sz=rot->sm=1;
}

void LinkNew(Treap *u,ci tp,ci v) {
    Treap *newp=pool[top--];
    newp->fa=u;newp->v=v;newp->key=mabs(int(GetRandom(sed)));
    newp->sz=newp->sm=1;
    if(tp < 0) u->ls=newp;
    else u->rs=newp;
}

void add(Treap* u,ci v) {
    int k=u->GetRelation(v);
    if(!k) {u->ChangeV(1);return;}
    else if(k < 0) {
        if(u->ls != NULL) add(u->ls,v);
        else LinkNew(u,-1,v);
        if(u->NeedTurn(u->ls)) u->RTurn();
    }
    else {
        if(u->rs != NULL) add(u->rs,v);
        else LinkNew(u,1,v);
        if(u->NeedTurn(u->rs)) u->LTurn();
    }
    u->update();
}

void dlt(Treap *u,ci v) {
    int k=u->GetRelation(v);
    if(!k) {
        u->ChangeV(-1);
        if(!(u->sm)) {u->dltit();pool[++top]=u;}
        return;
    }
    else if(k < 0) dlt(u->ls,v);
    else dlt(u->rs,v);
    u->update();
}

int askrnk(Treap *u,ci v) {
    int k=u->GetRelation(v);
    if(!k) {
        if(u->ls) return u->ls->sz+1;
        else return 1;
    }
    else if(k < 0) return askrnk(u->ls,v);
    else {
        if(u->ls) return askrnk(u->rs,v)+u->sm+u->ls->sz;
        else return askrnk(u->rs,v)+u->sm;
    }
}

int asknum(Treap *u,ci v) {
    int s=u->sm;
    if(u->ls) {
        int k=u->ls->sz;
        if(k >= v) return asknum(u->ls,v);
        s+=u->ls->sz;
    }
    if(s >= v) return u->v;
    else return asknum(u->rs,v-s);
}

int askpre(Treap *u,ci v) {
    if(u->v < v) {
        if(u->rs) return mmax(askpre(u->rs,v),u->v);
        else return u->v;
    }
    if(u->ls) return askpre(u->ls,v);
    return -INF;
}

int askpro(Treap *u,ci v) {
    if(u->v > v) {
        if(u->ls) return mmin(askpro(u->ls,v),u->v);
        else return u->v;
    }
    if(u->rs) return askpro(u->rs,v);
    return INF;
}

【数据结构】【平衡树】treap的更多相关文章

  1. hiho #1325 : 平衡树·Treap

    #1325 : 平衡树·Treap 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:小Hi,我发现我们以前讲过的两个数据结构特别相似. 小Hi:你说的是哪两个啊? ...

  2. hiho一下103周 平衡树·Treap

    平衡树·Treap 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:小Hi,我发现我们以前讲过的两个数据结构特别相似. 小Hi:你说的是哪两个啊? 小Ho:就是二 ...

  3. Hihocoder 1325 平衡树·Treap(平衡树,Treap)

    Hihocoder 1325 平衡树·Treap(平衡树,Treap) Description 小Ho:小Hi,我发现我们以前讲过的两个数据结构特别相似. 小Hi:你说的是哪两个啊? 小Ho:就是二叉 ...

  4. HihoCoder 1325 平衡树·Treap

    HihoCoder 1325 平衡树·Treap 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:小Hi,我发现我们以前讲过的两个数据结构特别相似. 小Hi:你说 ...

  5. 普通平衡树Treap(含旋转)学习笔记

    浅谈普通平衡树Treap 平衡树,Treap=Tree+heap这是一个很形象的东西 我们要维护一棵树,它满足堆的性质和二叉查找树的性质(BST),这样的二叉树我们叫做平衡树 并且平衡树它的结构是接近 ...

  6. HihoCoder1325 : 平衡树·Treap(附STL版本)

    平衡树·Treap 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:小Hi,我发现我们以前讲过的两个数据结构特别相似. 小Hi:你说的是哪两个啊? 小Ho:就是二 ...

  7. 算法模板——平衡树Treap 2

    实现功能:同平衡树Treap 1(BZOJ3224 / tyvj1728) 这次的模板有了不少的改进,显然更加美观了,几乎每个部分都有了不少简化,尤其是删除部分,这个参照了hzwer神犇的写法,在此鸣 ...

  8. 【山东省选2008】郁闷的小J 平衡树Treap

    小J是国家图书馆的一位图书管理员,他的工作是管理一个巨大的书架.虽然他很能吃苦耐劳,但是由于这个书架十分巨大,所以他的工作效率总是很低,以致他面临着被解雇的危险,这也正是他所郁闷的.具体说来,书架由N ...

  9. luoguP3369[模板]普通平衡树(Treap/SBT) 题解

    链接一下题目:luoguP3369[模板]普通平衡树(Treap/SBT) 平衡树解析 #include<iostream> #include<cstdlib> #includ ...

  10. 2021.12.06 平衡树——Treap

    2021.12.06 平衡树--Treap https://www.luogu.com.cn/blog/HOJQVFNA/qian-xi-treap-ping-heng-shu 1.二叉搜索树 1.1 ...

随机推荐

  1. PHP核心技术——魔术方法

    魔术方法: 魔术方法是以两个下画线开头.具有特殊作用的一些方法,可以看做PHP的"语法糖". set和get方法: class Account{ private $user=1; ...

  2. 简析Monte Carlo与TD算法的相关问题

    Monte Carlo算法是否能够做到一步更新,即在线学习? 答案显然是不能,如果可以的话,TD算法还有何存在的意义?MC算法必须要等到episode结束后才可以进行值估计的主要原因在于对Return ...

  3. Python常用模块之Pygame(手册篇:首页)

    Pygame手册官方网址:http://www.pygame.org/docs/ Pygame首页 说明文档: 自述 关于Pygame的基本信息,它是什么,谁参与了以及在哪里找到它. 安装 在几个平台 ...

  4. Oracle数据库拼音首字母模糊搜索

    1.建立函数 CREATE OR REPLACE FUNCTION F_PINYIN(P_NAME IN VARCHAR2) RETURN VARCHAR2 AS V_COMPARE ); V_RET ...

  5. Optimized Flow Migration for NFV Elasticity Control

    NFV弹性控制中的流迁移优化 ABSTRACT 基于动态创建和移除网络功能实例,NFV在网络功能控制上有很大的弹性.比如,网络功能和并,网络功能拆分,负载均衡等等. 那么为了实现弹性控制,就需要网络流 ...

  6. Eclipse的黑色主题背景(github)

    MoonRise UI Theme   An early version of a dark UI theme for Eclipse 4+. Requirements Eclipse 4.2+ In ...

  7. CA如何吊销签署过的证书

    1: 客户端获取要吊销证书的serial(在使用证书上的主机执行) openssl x509 -in httpd.crt -noout -serial -subject   2:拿到证书的编号后,通过 ...

  8. 安装DHCP 服务器 指的是由服务器控制一段IP地址范围,客户机登录服务器时就可以自动获得服务器分配的IP地址和子网掩码

    DHCP服务详解 前言:动态主机配置协议,给局域网内的主机分配IP地址,子网掩码,网关,DNS ARP协议 arp: address resolveing protocol (地址解析协议) 实现:I ...

  9. 1014 我的C语言文法定义与C程序推导过程

    程序> -> <外部声明> | <程序> <外部声明> <外部声明> -> <函数定义> | <声明> < ...

  10. LoadRunner脚本增强技巧之参数化(二)

    特别提醒: 1.在形成数据池之后,数据库中的数据变化不会影响数据池中的数据. 2.数据文件一定要以一个空行结束,否则,最后一行输入的数据不会被参数所使用. 3.一般我们用到的很多的都是使用数据文件来保 ...