描述

初始有一个空集,依次插入N个数Ai。有M次询问Bj,表示询问第Bj个数加入集合后的排名为j的数是多少

输入

第一行是两个整数N,M

接下来一行有N个整数,Ai

接下来一行有M个整数Bj,保证数据合法

输出

M行,回答每个询问

样例输入

7 4

9 7 2 8 14 1 8

1 2 6 6

样例输出

9

9

7

8

提示

【说明】

第一次询问,当前集合{9},1th=9

第二次询问,当前集合{9,7}的第2=9

第三次询问,当前集合{9,7,2,8,14,1}的第3=7

第四次询问,当前集合{9,7,2,8,14,1}的第4=8

【数据规模】

40%的数据保证 n ≤ 1000

100%的数据保证1≤m≤n≤30000;0≤Ai<2^32

康复训练ing。。。

一道裸的不能再裸的非旋treap的模板题。。。

代码:

#include<bits/stdc++.h>
#define ll long long
#define N 30005
using namespace std;
inline ll read(){
    ll ans=0;
    char ch=getchar();
    while(!isdigit(ch))ch=getchar();
    while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
    return ans;
}
inline void write(ll x){
    if(x>9)write(x/10);
    putchar((x%10)^48);
}
ll a[N],ans[N];
struct Node{int tim,id;}b[N];
int n,m;
typedef pair<int,int> pii;
struct fhq_treap{
    int rt,cnt,son[N][2],rd[N],siz[N];
    ll val[N];
    inline int build(ll v){siz[++cnt]=1,rd[cnt]=rand(),val[cnt]=v,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 pii split(int p,int k){
        if(!p)return pii(0,0);
        pii tmp;
        if(siz[son[p][0]]>=k){
            tmp=split(son[p][0],k);
            son[p][0]=tmp.second,pushup(p);
            return make_pair(tmp.first,p);
        }
        tmp=split(son[p][1],k-siz[son[p][0]]-1);
        son[p][1]=tmp.first,pushup(p);
        return make_pair(p,tmp.second);
    }
    inline int rank(int p,ll v){
        if(!p)return 0;
        if(val[p]>v)return rank(son[p][0],v);
        return siz[son[p][0]]+1+rank(son[p][1],v);
    }
    inline ll kth(int k){
        pii x=split(rt,k),y=split(x.first,k-1);
        rt=merge(merge(y.first,y.second),x.second);
        return val[y.second];
    }
    inline void insert(ll v){
        int k=rank(rt,v),p=build(v);
        pii x=split(rt,k);
        rt=merge(merge(x.first,p),x.second);
    }
}T;
inline bool cmp(Node a,Node b){return a.tim<b.tim;}
int main(){
    srand(time(NULL));
    n=read(),m=read();
    for(int i=1;i<=n;++i)a[i]=read();
    for(int i=1;i<=m;++i)b[i].tim=read(),b[i].id=i;
    sort(b+1,b+m+1,cmp);
    for(int i=1;i<=m;++i){
        Node q=b[i];
        for(int j=b[i-1].tim+1;j<=q.tim;++j)T.insert(a[j]);
        ans[q.id]=T.kth(q.id);
    }
    for(int i=1;i<=m;++i)write(ans[i]),puts("");
    return 0;
}

2018.08.27 rollcall(非旋treap)的更多相关文章

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

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

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

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

  3. 2018.07.24 loj#107. 维护全序集(非旋treap)

    传送门 就是普通平衡树,可以拿来练非旋treap" role="presentation" style="position: relative;"&g ...

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

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

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

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

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

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

  7. 平衡树简单教程及模板(splay, 替罪羊树, 非旋treap)

    原文链接https://www.cnblogs.com/zhouzhendong/p/Balanced-Binary-Tree.html 注意是简单教程,不是入门教程. splay 1. 旋转: 假设 ...

  8. 2827: 千山鸟飞绝 非旋treap

    国际惯例的题面:看起来很不可做的样子,我们先来整理一下题意吧.就是,维护每个点曾经拥有过的最大的两个属性值,支持把点的位置移动.我们用map对每个位置进行离散化,对每个位置建立一个平衡树.为了方便分离 ...

  9. 2081.09.22 Kuma(非旋treap)

    描述 有N张卡片,编号从0到n-1, 刚开始从0到n-1按顺序排好. 现有一个操作, 对于p. l,表示从第p张卡片之后的l张卡片拿到 最前面. 例如n=7的时候, 刚开始卡片序列为0 1 2 3 4 ...

随机推荐

  1. ABAP-SMARTFORMS

  2. C++Primer笔记-----day08

    ==========================================================================day08===================== ...

  3. 【转】.net 实现 语音搜索(仅限WebKit内核浏览器)

    <input type="text" class="text" name="value_2" id="value_2&quo ...

  4. 多字段非连续模糊查询java实现

    工作需要,写了一个实现数据库多字段模糊查询的方法,背景是输入用户的信息,如用户的userid,姓名,拼音等,可以查出相关的用户 具体如下 1. 操作一张表,可以设置表前缀 2. 可以实现中文的不连续查 ...

  5. unity WWW加载进度条

    using UnityEngine; using System.Collections; public class testProgress : MonoBehaviour { void Start ...

  6. Kotlin语言学习笔记(7)

    反射 // 反射 val c = MyClass::class val c2 = MyClass::class.java // 获取KClass的引用 val widget: Widget = ... ...

  7. REST Client

    1.  为什么要使用REST Client 在实际企业开发过程中经常会有这样的需求: 1.我当前开发的这个系统是需要调用其他系统的接口,也就是我们需要频繁的测试接口,尝试不同的入参参数去查看返回结果, ...

  8. mysql 导入csv 转义

    TERMINATED :分隔符 ESCAPED :转义用什么标示,‘’ 不设置转义符 LOAD DATA LOCAL INFILE '/home/tmp/1999/holder.csv'  INTO ...

  9. Redis 发布与订阅 消息

    基于Redis消息队列-实现短信服务化 1.Redis实现消息队列原理 常用的消息队列有RabbitMQ,ActiveMQ,个人觉得这种消息队列太大太重,本文介绍下基于Redis的轻量级消息队列服务. ...

  10. 使用JSON.parse()转化成json对象需要注意的地方

    http://blog.csdn.net/u011277123/article/details/53055479 有三种方法: var str = '{"name":"小 ...