3224: Tyvj 1728 普通平衡树

Time Limit: 1 Sec  Memory Limit: 256 MB

题目连接

http://www.lydsy.com/JudgeOnline/problem.php?id=3224

Description

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

Input

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

Output

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

Sample Input

10

1 106465

4 1

1 317721

1 460929

1 644985

1 84185

1 89851

6 81968

1 492737

5 493598

Sample Output

106465

84185

492737

HINT

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

题意

题解:

用一个vector来做

虽然感觉用set也行

代码:

//qscqesze
#include <cstdio>
#include <cmath>
#include <cstring>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <sstream>
#include <queue>
#include <typeinfo>
#include <fstream>
#include <map>
#include <stack>
typedef long long ll;
using namespace std;
//freopen("D.in","r",stdin);
//freopen("D.out","w",stdout);
#define sspeed ios_base::sync_with_stdio(0);cin.tie(0)
#define maxn 200001
#define mod 10007
#define eps 1e-9
int Num;
char CH[20];
//const int inf=0x7fffffff;   //无限大
const int inf=0x3f3f3f3f;
/*inline void P(int x)
{Num=0;if(!x){putchar('0');puts("");return;}while(x>0)CH[++Num]=x%10,x/=10;while(Num)putchar(CH[Num--]+48);puts("");
}
*/
//**************************************************************************************
inline ll 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;
}
inline void P(int x)
{Num=0;if(!x){putchar('0');puts("");return;}while(x>0)CH[++Num]=x%10,x/=10;while(Num)putchar(CH[Num--]+48);puts("");
}vector<int> q;
int main()
{int t=read();while(t--){int n=read(),m=read();if(n==1)q.insert(upper_bound(q.begin(),q.end(),m),m);if(n==2)q.erase(lower_bound(q.begin(),q.end(),m));if(n==3)printf("%d\n",lower_bound(q.begin(),q.end(),m)-q.begin()+1);if(n==4)printf("%d\n",q[m-1]);if(n==5)printf("%d\n",*--lower_bound(q.begin(),q.end(),m));if(n==6)printf("%d\n",*upper_bound(q.begin(),q.end(),m));}
}

转载于:https://www.cnblogs.com/qscqesze/p/4442006.html

bzoj 3224 普通平衡树 vactor的妙用相关推荐

  1. BZOJ 3224 普通平衡树 treap or vector

    很明显这是一道treap的题,但看了黄学长的博客后,也让我大开了眼界,没想到vector也能用那么短的编码量把这道题AC,着实令我敬佩.这也提醒了我 STL 的重要性. 的确, 对于C++ 选手来说, ...

  2. BZOJ 3224: Tyvj 1728 普通平衡树【Treap】

    3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MB Description 您需要写一种数据结构(可参考题目标题),来维护一些数 ...

  3. BZOJ 3223 文艺平衡树

    BZOJ 3223 文艺平衡树 题意 一个 1~n 的序列,有m次询问,每次询问翻转其中的一个区间.输出最后的区间. 题解 这是一棵加lazy的平衡树-- 首先,翻转区间可以通过区间内所有节点的左右儿 ...

  4. BZOJ 3224: Tyvj 1728 普通平衡树 treap

    3224: Tyvj 1728 普通平衡树 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/p ...

  5. BZOJ 3224: Tyvj 1728 普通平衡树

    3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec  Memory Limit: 128 MB Submit: 9629  Solved: 4091 [Submit][S ...

  6. Treap树堆(bzoj 3224: Tyvj 1728 普通平衡树)

    Treap树堆:一种排序二叉树(中序遍历权值有序) 每个节点有两个关键字:key[]和rand[] 其中key[]满足二叉搜索树性质,rand[]满足堆性质(即Tree+Heap=Treap)即 如果 ...

  7. 【Treap】[BZOJ 3224]Tyvj 1728 普通平衡树

    平衡树的入门题目,也可以用Treap来实现,我觉得Treap的核心就是那个rand()了用来保证树不退化成链,同时还是有平衡树的特性..总体来说我觉得比较好些,而且比较快 #include <c ...

  8. bzoj:3224: Tyvj 1728 普通平衡树

    Description 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作: 1. 插入x数 2. 删除x数(若有多个相同的数,因只删除一个) 3. 查询x数的排名(若有多个相 ...

  9. bzoj 3224 Tyvj 1728 普通平衡树

    题目大意: 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作: 1. 插入x数 2. 删除x数(若有多个相同的数,因只删除一个) 3. 查询x数的排名(若有多个相同的数,因输 ...

最新文章

  1. mysql not in语句_MySQL命令
  2. 全球 Top 10 高材生赴神策数据的交流访问之旅
  3. Effectice Java之始终覆盖toString(十)
  4. Learning python学习总结之字符串方法
  5. 卡通角色表情驱动系列二
  6. LeetCode 654. 最大二叉树(递归)
  7. loadrunner工具的组成
  8. 5.1 损坏联机日志的恢复方法
  9. hystrix源码小贴士之中断
  10. iOS 为自定义返回按钮的页面添加右滑返回
  11. php接收不到url传值_【干货】PHP 异步后台处理
  12. 团队项目-个人博客-4.27
  13. 凸优化第七章统计估计 7.1 参数分布估计
  14. Caffe学习:使用pycaffe绘制loss、accuracy曲线
  15. 例2.8 叠筐 - 九度教程第15题(排版题)
  16. 合并传闻是真是假?ofo摩拜之争是否继续?(产品)
  17. 地理国情监测云平台简介
  18. autojs写的全网视频解析app,带解析接口。
  19. git本地仓库关联远程仓库的两种方式
  20. 荣耀十支持鸿蒙OS,不是所有华为荣耀手机都能升级华为鸿蒙OS,只有这48款才行...

热门文章

  1. js如何获取文本节点的值?
  2. Android面试题目整理与讲解
  3. clojure入门: hello world
  4. 八数码 poj 1077 广搜 A* IDA*
  5. Makefile_06:如果引用其它的 Makefile
  6. a[0]和a 的区别?
  7. 常考数据结构和算法:跳台阶
  8. 实验吧 登录一下好吗
  9. 给共享程序集延迟签名
  10. 《30天自制操作系统》笔记(01)——hello bitzhuwei’s OS!