洛谷 P3369 BZOJ 3224 【模板】普通平衡树(Treap/SBT)

简介: 题目描述 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作: 插入x数 删除x数(若有多个相同的数,因只删除一个) 查询x数的排名(若有多个相同的数,因输出最小的排名) 查询排名为x的数 求x的前驱(前驱定义为小于x,且最大...

题目描述

您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:

  1. 插入x数

  2. 删除x数(若有多个相同的数,因只删除一个)

  3. 查询x数的排名(若有多个相同的数,因输出最小的排名)

  4. 查询排名为x的数

  5. 求x的前驱(前驱定义为小于x,且最大的数)

  6. 求x的后继(后继定义为大于x,且最小的数)

输入输出格式

输入格式:

 

第一行为n,表示操作的个数,下面n行每行有两个数opt和x,opt表示操作的序号(1<=opt<=6)

 

输出格式:

 

对于操作3,4,5,6每行输出一个数,表示对应答案

 

输入输出样例

输入样例#1:
10
1 106465
4 1
1 317721
1 460929
1 644985
1 84185
1 89851
6 81968
1 492737
5 493598
输出样例#1:
106465
84185
492737

说明

时空限制:1000ms,128M

1.n的数据范围:n<=100000

2.每个数的数据范围:[-1e7,1e7]

来源:Tyvj1728 原名:普通平衡树

在此鸣谢

解题思路

  1、直接上平衡树的板子,手敲也好,pb_ds也罢,这里先留坑……

  2、黄学长博客上看到的二分查找,好神奇……Orz

源代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<set>
#include<vector>
#include<algorithm>
#define inf 1000000000
using namespace std;
inline int read()
{
    int x=0,f=1;char ch=getchar();
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
    return x*f;
}
int n;
vector<int> a;
void insert(int x)
{
    a.insert(upper_bound(a.begin(),a.end(),x),x);
    return;
}
void del(int x)
{
    a.erase(lower_bound(a.begin(),a.end(),x));
    return;
}
int find(int x)
{
    return lower_bound(a.begin(),a.end(),x)-a.begin()+1;
}
int main()
{
    n=read();
    a.reserve(200000);
    int f,x;
    for(int i=1;i<=n;i++)
    {
        f=read();x=read();
        switch(f)
        {
        case 1:insert(x);break;
        case 2:del(x);break;
        case 3:printf("%d\n",find(x));break;
        case 4:printf("%d\n",a[x-1]);break;
        case 5:printf("%d\n",*--lower_bound(a.begin(),a.end(),x));break;
        case 6:printf("%d\n",*upper_bound(a.begin(),a.end(),x));break;
        }
    }
    return 0;
}

 

目录
相关文章
|
6月前
|
API
【二叉树】练习题终章
【二叉树】练习题终章
49 0
|
6月前
|
算法 vr&ar 图形学
☆打卡算法☆LeetCode 145. 二叉树的后序遍历 算法解析
☆打卡算法☆LeetCode 145. 二叉树的后序遍历 算法解析
|
算法
代码随想录算法训练营第十七天 | LeetCode 110. 平衡二叉树、257. 二叉树的所有路径、404. 左叶子之和
代码随想录算法训练营第十七天 | LeetCode 110. 平衡二叉树、257. 二叉树的所有路径、404. 左叶子之和
42 0
《蓝桥杯每日一题》递归·AcWing 1497. 树的遍历
《蓝桥杯每日一题》递归·AcWing 1497. 树的遍历
60 0
|
算法
数据结构实验十四 二叉排序树
数据结构实验十四 二叉排序树
63 0
|
机器学习/深度学习
【每日一题Day107】LC1145二叉树着色游戏 | dfs+贪心
现在,假设你是「二号」玩家,根据所给出的输入,假如存在一个 y 值可以确保你赢得这场游戏,则返回 true ;若无法获胜,就请返回 false 。
98 0
【每日一题Day107】LC1145二叉树着色游戏 | dfs+贪心
Codeforces1153——D. Serval and Rooted Tree(思维好题+dfs+贪心)
Codeforces1153——D. Serval and Rooted Tree(思维好题+dfs+贪心)
129 0
Codeforces1153——D. Serval and Rooted Tree(思维好题+dfs+贪心)
POJ-1308,Is It A Tree?(并查集和树)
POJ-1308,Is It A Tree?(并查集和树)
|
算法 前端开发 程序员
「LeetCode」617-合并二叉树⚡️
「LeetCode」617-合并二叉树⚡️
138 0
「LeetCode」617-合并二叉树⚡️
|
算法 前端开发 程序员
「LeetCode」257-二叉树的所有路径⚡️
「LeetCode」257-二叉树的所有路径⚡️
117 0
「LeetCode」257-二叉树的所有路径⚡️