bzoj 3224 Tyvj 1728 普通平衡树

题目大意:

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

1. 插入x数

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

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

4. 查询排名为x的数

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

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

思路:

直接splay

今天才敲。。。

  1 #include<iostream>
  2 #include<cstdio>
  3 #include<cmath>
  4 #include<cstdlib>
  5 #include<cstring>
  6 #include<algorithm>
  7 #include<vector>
  8 #include<queue>
  9 #define inf 2139062143
 10 #define ll long long
 11 #define MAXN 100100 
 12 #define MOD 1000000007
 13 using namespace std;
 14 inline int read()
 15 {
 16     int x=0,f=1;char ch=getchar();
 17     while(!isdigit(ch)) {if(ch=='-') f=-1;ch=getchar();}
 18     while(isdigit(ch)) {x=x*10+ch-'0';ch=getchar();}
 19     return x*f;
 20 }
 21 int ch[MAXN][2],fa[MAXN],sz,cnt[MAXN],val[MAXN],size[MAXN],rt;
 22 int which(int x) {return x==ch[fa[x]][1];}
 23 int find_pre()
 24 {
 25     int pos=ch[rt][0];
 26     while(ch[pos][1]) pos=ch[pos][1];
 27     return pos;
 28 }
 29 int find_sub()
 30 {
 31     int pos=ch[rt][1];
 32     while(ch[pos][0]) pos=ch[pos][0];
 33     return pos;
 34 }
 35 void upd(int x)
 36 {
 37     if(!x) return ;
 38     size[x]=cnt[x]+size[ch[x][1]]+size[ch[x][0]];
 39 }
 40 void rotate(int pos)
 41 {
 42     int f=fa[pos],ff=fa[f],k=which(pos);
 43     ch[f][k]=ch[pos][k^1],fa[ch[f][k]]=f,fa[f]=pos,ch[pos][k^1]=f,fa[pos]=ff;
 44     if(ff) ch[ff][ch[ff][1]==f]=pos;
 45     upd(f);upd(pos);
 46 }
 47 void splay(int x)
 48 {
 49     for(int f;f=fa[x];rotate(x))
 50         if(fa[f]) rotate((which(x)==which(f)?f:x));
 51     rt=x;
 52 }
 53 void Insert(int x)
 54 {
 55     int pos=rt,f=0;
 56     while(1)
 57     {
 58         if(val[pos]==x) {cnt[pos]++,upd(pos);upd(f);splay(pos);return ;}
 59         f=pos,pos=ch[pos][x>val[pos]];
 60         if(!pos)
 61         {
 62             ch[++sz][0]=ch[sz][1]=0,fa[sz]=f,val[sz]=x,cnt[sz]=size[sz]=1,ch[f][x>val[f]]=sz;
 63             upd(f);splay(sz);return ;
 64         }
 65     }
 66 }
 67 void insert(int x)
 68 {
 69     if(!rt) {val[++sz]=x,ch[sz][0]=ch[sz][1]=fa[sz]=0,cnt[sz]=size[sz]=1,rt=sz;return;}
 70     Insert(x);
 71 }
 72 int find_rank(int x)
 73 {
 74     int res=0,pos=rt;
 75     while(1)
 76     {
 77         if(x<val[pos]) pos=ch[pos][0];
 78         else
 79         {
 80             res+=size[ch[pos][0]];
 81             if(val[pos]==x) {splay(pos);return res+1;}
 82             res+=cnt[pos],pos=ch[pos][1];
 83         }
 84     }
 85 }
 86 int find_num(int x)
 87 {
 88     int tmp=0,pos=rt;
 89     while(1)
 90     {
 91         if(ch[pos][0]&&x<=size[ch[pos][0]]) pos=ch[pos][0];
 92         else
 93         {
 94             tmp=size[ch[pos][0]]+cnt[pos];
 95             if(x<=tmp) return val[pos];
 96             x-=tmp,pos=ch[pos][1];
 97         }
 98     }
 99 }
100 void dlt(int x)
101 {
102     find_rank(x);
103     if(cnt[rt]>1) {cnt[rt]--;return ;}
104     if(!ch[rt][0]&&!ch[rt][1]) {rt=0;return ;}
105     if(!ch[rt][0]||!ch[rt][1])
106     {
107         int k=!ch[rt][1]?0:1;
108         rt=ch[rt][k],fa[rt]=0;
109         return ;
110     }
111     int k=find_pre(),tmp=rt;
112     splay(k);fa[ch[tmp][1]]=rt;
113     ch[rt][1]=ch[tmp][1],rt=k;
114 }
115 int main()
116 {
117     int T=read(),opt,x;
118     while(T--)
119     {
120         opt=read(),x=read();
121         if(opt==1) insert(x);
122         if(opt==2) dlt(x);
123         if(opt==3) printf("%d\n",find_rank(x));
124         if(opt==4) printf("%d\n",find_num(x));
125         if(opt==5) {insert(x);printf("%d\n",val[find_pre()]);dlt(x);}
126         if(opt==6) {insert(x);printf("%d\n",val[find_sub()]);dlt(x);}
127     }
128 }
View Code

 

转载于:https://www.cnblogs.com/yyc-jack-0920/p/8047274.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/252677.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

不懂毫米波雷达?5分钟读懂毫米波雷达的那些事儿

2019年是毫米波风生水起的一年&#xff0c;也是毫米波名声大噪的一年。毫米波应用范围广泛&#xff0c;如毫米波雷达、毫米波天线等。而本文&#xff0c;将向大家介绍毫米波雷达&#xff0c;主要内容包括&#xff1a;毫米波雷达原理、毫米波雷达主要特点、毫米波雷达优势以及毫…

redis集群的搭建

########环境######### centos 7.2 , gcch 环境ruby 2.0.0 redis 3.2.8 redis-3.3.3gem 公司要求搭建redis集群, 本来觉得挺好搞的,没想到弄到现在.... 1, 环境准备 gcc , ruby 等环境准备 yum -y install gcc ruby ruby-devel rubygems rpm-build zlib redis-ruby接口安装, 我…

2017-2018-1 20155227 《信息安全系统设计基础》第十三周学习总结

2017-2018-1 20155227 《信息安全系统设计基础》第十三周学习总结 找出全书你认为最重要的一章&#xff0c;深入重新学习一下&#xff0c;要求&#xff08;期末占10分&#xff09;&#xff1a; 完成这一章所有习题详细总结本章要点给你的结对学习搭档讲解你的总结并获取反馈我选…

进程间五种通信方式

进程间通信&#xff08;IPC&#xff0c;InterProcess Communication&#xff09;是指在不同进程之间传播或交换信息。 IPC的方式通常有管道&#xff08;包括无名管道和命名管道&#xff09;、消息队列、信号量、共享存储、Socket、Streams等。其中 Socket和Streams支持不同主机…

电子书下载:Silverlight 5 in Action

下载&#xff1a;http://www.ctdisk.com/file/8447319

Virtualbox桥接网卡设置

正常情况下&#xff0c;像设置virtualbox虚拟机的桥接网卡非常简单&#xff0c;只需要点配置&#xff0c;然后在配置界面点击网络&#xff0c;然后在右边的网络里选择桥接网络即可。但是如果这么简单就好了&#xff0c;今天要说的就是在不正常的情况下是怎么设置的。 工具/原料…

SQL疑难杂症【4 】大量数据查询的时候避免子查询

前几天发现系统变得很慢&#xff0c;在Profiler里面发现有的SQL执行了几十秒才返回结果&#xff0c;当时的SQL如下&#xff1a; 可以看得出来&#xff0c;在652行用了子查询&#xff0c;恰巧目标表(QS_WIP)中的记录数为100000000&#xff0c;通过如下SQL可以得到&#xff1a; S…

『原创』一个基于Win CE 5.0的Txt文件阅读器

最近&#xff0c;拿到一台亲戚送的GPS导航仪&#xff0c;其系统是基于WinCE5.0的&#xff0c;所以我觉得可以写点小程序上去&#xff0c;上网一搜&#xff0c;还附带破解方法&#xff0c;把GPS破解后就变成一台屏幕超大的PDA了&#xff0c;于是我想用它看电子书&#xff0c;无奈…

ARM Cortex-A系列(A53、A57、A73等)处理器性能分类与对比

在如今这个电子产品泛滥的年代&#xff0c;仅仅靠品牌或是外观已经不足以辨别产品的优劣&#xff0c;其内置的处理器自然也就成为了分辨产品是否高端的标准之一。那么我们今天就不妨好好了解一下近几年来电子产品中较为主流的RAM处理器。 在这之前让我们先简单认识一下处理器的…

.NET 3.5 - DLINQ(LINQ to SQL)之面向对象的添加、查询、更新和删除

步步为营VS 2008 .NET 3.5(8) - DLINQ(LINQ to SQL)之面向对象的添加、查询、更新和删除作者&#xff1a;webabcd介绍以Northwind为示例数据库&#xff0c;DLINQ(LINQ to SQL)之完全面向对象的添加操作、查询操作、更新操作和删除操作示例Sample.aspx <% Page Language&quo…

ARM版本系列及家族成员梳理

ARM公司简介 ARM是Advanced RISC Machines的缩写&#xff0c;它是一家微处理器行业的知名企业&#xff0c;该企业设计了大量高性能、廉价、耗能低的RISC &#xff08;精简指令集&#xff09;处理器。 1985年第一个ARM原型在英国剑桥诞生。 公司的特点是只设计芯片&#xff0c…

tomcat源码阅读之StandardHost和StandardEngine

StandardHost及UML类图&#xff1a; 1、StandardHost类是Host接口的默认实现&#xff1b;其继承自ContainerBase类&#xff0c;说明他也是一个容器类&#xff0c;既然是容器类&#xff0c;那肯定也有管道对象PipeLine和阀门&#xff0c;其基础阀门&#xff08;Basic Valve&…

安防监控产业链全景梳理

安防行业是随着现代社会安全需求应运而生的产业&#xff0c;围绕着视频监控技术的改革创新&#xff0c;行业从“看得见、看得远、看得清到看得懂”&#xff0c;一共经历模拟监控、数字监控、网络高清监控和智能监控4个阶段&#xff0c;每一阶段的突破&#xff0c;都由上游技术的…

Vue项目搭建步骤

一&#xff0e; vue-cli初始化1. 全局安装 vue-cli  npm install --global vue-cli2. 创建一个基于 webpack 模板的新项目  vue init webpack my-project3. 安装依赖  cd my-project  npm install (换源安装: npm install --registry https://registry.npm.taobao.org …

Python tutor 简介

Python tutor 能够直观显示object 引用关系。 网址是 http://www.pythontutor.com/visualize.html 先分享一下我的一个Python tutor&#xff1a; 点我出现神奇&#xff1a; 1&#xff09; 编辑code。 2&#xff09; 运行&#xff0c; 能够看到以下界面。 这个工具是很酷的&…

光学镜头行业发展现状及趋势,智能手机应用领域占比最高

一、光学镜头分类 光学镜头也叫摄像镜头或摄影镜头&#xff0c;简称镜头&#xff0c;其功能就是光学成像。光学镜头是光学成像系统中的必备组件&#xff0c;直接影响到成像质量的好坏&#xff0c;影响算法的实现和效果。从结构来看&#xff0c;光学镜头一般由精密五金、塑胶零…

关于_vmvare workstation装32ubuntu的问题

刚开始启动的时候是黑屏&#xff0c;没有任何反应 1.bios也设置BIOS intel virtual technology 设置了enabled(开启硬件虚拟化:要运行一些操作系统&#xff0c;虚拟化软件和虚拟机&#xff0c;硬件虚拟化就需要启用。大多数情况下&#xff0c;不需要虚拟化技术的操作系统可以正…

360°环视(全景影像)系统发展趋势

360环视系统&#xff0c;系统同时采集车辆四周的影像&#xff0c;经过图像处理单元一系列的智能算法处理&#xff0c;最终形成一幅车辆四周的全景俯视图显示在屏幕上&#xff0c;直观地呈现出车辆所处的位置和周边情况。系统大大地拓展了驾驶员对周围和环境的感知能力&#xff…

数学之路(3)-机器学习(3)-机器学习算法-SVM[7]

SVM是新近出现的强大的数据挖掘工具&#xff0c;它在文本分类、手写文字识别、图像分类、生物序列分析等实际应用中表现出非常好的性能。SVM属于监督学习算法&#xff0c;样本以属性向量的形式提供&#xff0c;所以输入空间是Rn的子集。 图1 如图1所示&#xff0c;SVM的目标是找…

CPU、GPU、FPGA、ASIC等AI芯片特性及对比

1、前言 目前&#xff0c;智能驾驶领域在处理深度学习AI算法方面&#xff0c;主要采用GPU、FPGA 等适合并行计算的通用芯片来实现加速。同时有部分芯片企业开始设计专门用于AI算法的ASIC专用芯片&#xff0c;比如谷歌TPU、地平线BPU等。在智能驾驶产业应用没有大规模兴起和批量…