两种操作,1是加入数字,二是找最接近的

用set或者平衡二叉树就好了

只写了二叉树的,套版子就好

#include<bits/stdc++.h>
#define sf scanf
#define scf(x) scanf("%d",&x)
#define scff(x,y) scanf("%d%d",&x,&y)
#define scfff(x,y,z) scanf("%d%d%d",&x,&y,&z)
#define pf printf
#define prf(x) printf("%d\n",x)
#define mm(x,b) memset((x),(b),sizeof(x))
#define rep(i,a,n) for (int i=a;i<n;i++)
#define per(i,a,n) for (int i=a;i>=n;i--)
typedef long long ll;
const ll mod=1e9+100;
const double eps=1e-8;
using namespace std;
const double pi=acos(-1.0);
const int inf=0xfffffff;
const int N=1e5+7;
struct node
{
int lc,rc,h,v;
}tree[N];
int pos=0,x1,x2,x3,root;
int right_rotate(int r)//zig右旋
{
int t = tree[r].lc;
tree[r].lc = tree[t].rc;
tree[t].rc = r;
tree[r].h = max(tree[tree[r].lc].h,tree[tree[r].rc].h)+1;
tree[t].h = max(tree[tree[t].lc].h,tree[tree[t].rc].h)+1;
return t;
}
int left_rotate(int r)//zag左旋
{
int t = tree[r].rc;
tree[r].rc = tree[t].lc;
tree[t].lc = r;
tree[r].h = max(tree[tree[r].lc].h,tree[tree[r].rc].h)+1;
tree[t].h = max(tree[tree[t].lc].h,tree[tree[t].rc].h)+1;
return t;
}
int right_left_rotate(int r)//zigzag双旋
{
tree[r].rc = right_rotate(tree[r].rc);
return left_rotate(r);
}
int left_right_rotate(int r)//zagzig双旋
{
tree[r].lc = left_rotate(tree[r].lc);
return right_rotate(r);
}
void maintain(int &r)
{
if(tree[tree[r].lc].h == tree[tree[r].rc].h+2)//左子树高了
{
int t = tree[r].lc;
if(tree[tree[t].lc].h == tree[tree[r].rc].h+1) r = right_rotate(r);//左子树的左儿子,对应第一种情况
else if(tree[tree[t].rc].h == tree[tree[r].rc].h+1) r = left_right_rotate(r);
}
else if(tree[tree[r].rc].h == tree[tree[r].lc].h+2)//右子树高了
{
int t = tree[r].rc;
if(tree[tree[t].rc].h == tree[tree[r].lc].h+1) r = left_rotate(r);//右子树的右儿子,对应第四种情况
else if(tree[tree[t].lc].h == tree[tree[r].lc].h+1) r = right_left_rotate(r);
}
tree[r].h = max(tree[tree[r].lc].h,tree[tree[r].rc].h)+1;//高度更新
}
void prem(int x,int r)//找x的前驱
{
if(r == 0) return;
if(tree[r].v < x)
{
x1 = tree[r].v;
prem(x,tree[r].rc);
}
else prem(x,tree[r].lc);
}
void nexm(int x,int r)//找x后一个数字
{
if(r == 0) return;
if(tree[r].v > x)
{
x2 = tree[r].v;
nexm(x,tree[r].lc);
}
else nexm(x,tree[r].rc);
}
void find(int x,int r)//找到x
{
if(r==0) return;
if(tree[r].v ==x)
{
x3=x;
return ;
}
if(tree[r].v > x)
find(x,tree[r].lc);
else
find(x,tree[r].rc);
}
int insert(int r,int x)
{
if(r == 0)//找到一个空的节点,赋值
{
tree[++pos].h = 1;//高度初始化
tree[pos].v = x;
return pos;
}
if(x < tree[r].v) tree[r].lc = insert(tree[r].lc,x);//插入的数小于根节点,因此在它的左子树插入
else if(x > tree[r].v) tree[r].rc = insert(tree[r].rc,x);
maintain(r);//维持节点r的平衡
return r;//返回新的根节点
}
int main()
{
int n,aa,x;scf(n);
while(n--)
{
scff(aa,x);
if(aa==1)
root=insert(root,x);
else
{
x1=x2=x3=0;
prem(x,root);
nexm(x,root);
find(x,root);
// cout<<x1<<" "<<x2<<endl;
if(x3)
prf(x3);
else if(x1==0&&x2==0)
pf("Empty!\n");
else if(x1==0)
prf(x2);
else if(x2==0)
prf(x1);
else
{
if(x-x1==x2-x)
pf("%d %d\n",x1,x2);
else
{
if(x-x1<x2-x)
prf(x1);
else
prf(x2);
}
}
}
}
return 0;
}

10.1jihe的更多相关文章

  1. Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级

    Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 5.安装Database软件 5. ...

  2. Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part1:准备工作

    Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part1:准备工作 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 1.实施前准备工作 1.1 服务器安装操 ...

  3. ArcGIS 10.0紧凑型切片读写方法

    首先介绍一下ArcGIS10.0的缓存机制: 切片方案 切片方案包括缓存的比例级别.切片尺寸和切片原点.这些属性定义缓存边界的存在位置,在某些客户端中叠加缓存时匹配这些属性十分重要.图像格式和抗锯齿等 ...

  4. CI Weekly #10 | 2017 DevOps 趋势预测

    2016 年的最后几个工作日,我们对 flow.ci Android & iOS 项目做了一些优化与修复: iOS 镜像 cocoapods 版本更新: fir iOS上传插件时间问题修复: ...

  5. 10个最好用的HTML/CSS 工具、插件和资料库

    大家在使用HTML/CSS开发项目的过程中,有使用过哪些工具,插件和库?下面介绍的10种HTML/CSS工具,插件和资料库,是国外程序员经常用到的. Firebug Lite FirebugLite ...

  6. 【Win 10 应用开发】启动远程设备上的应用

    这个功能必须在“红石-1”(build 14393)以上的系统版中才能使用,运行在一台设备上的应用,可以通过URI来启动另一台设备上的应用.激活远程应用需要以下前提: 系统必须是build 14393 ...

  7. 在Ubuntu 16.10安装mysql workbench报未安装软件包 libpng12-0错误

    1.安装mysql workbench,提示未安装软件包 libpng12-0 下载了MySQL Workbench 6.3.8   在安装的时候报错: -1ubu1604-amd64.deb 提示: ...

  8. Ubuntu 16.10 安装byzanz截取动态效果图工具

    1.了解byzanz截取动态效果图工具 byzanz能制作文件小,清晰的GIF动态效果图,不足就是,目前只能通过输入命令方式来录制. byzanz主要的参数选项有: -d, --duration=SE ...

  9. Ubuntu 16.10 安装KolourPaint 4画图工具

    KolourPaint 4画图工具简单实用,可以绘画.视频处理和图标编辑: • 绘画:绘制图表和“手绘” • 视频处理:编辑截图和照片;应用特效 • 图标编辑:绘画剪贴和标识透明化 1.在Ubuntu ...

随机推荐

  1. java.lang.OutOfMemoryError: Java heap space内存不足问题

    今晚,在定义一个new int[19001][13001]的数组时候内存不够:特转了一下方法: Exception in thread "main" java.lang.OutOf ...

  2. PHP7 学习笔记(十七)变量函数 - unset

    https://secure.php.net/manual/zh/function.unset.php unset()函数用来清除.销毁变量,不用的变量,可以用unset()将它销毁. 1.unset ...

  3. 2017-2018-2 PDE 讨论班

    等等. 第一次上课居然忘记怎么让笔记本电脑和投影仪相连了. 有两个接口. 一个在外面, 没用. 一个盖着了, 忘记翻开了.

  4. 基于STM32F1的局域网通信模块W5500驱动

    目录 说明 W5500 W5500.c 使用方法 说明 需要调整的内容为W5500.h中关于IP地址.端口号.子网掩码.网关等参数 W5500 #ifndef _W5500_H_ #define _W ...

  5. day 15 - 1 内置函数

    内置函数 作用域相关 locals() globals() #这两组开始容易搞混 print(locals()) #返回本地作用域中的所有名字 print(globals()) #返回全局作用域中的所 ...

  6. spring事务源码分析结合mybatis源码(一)

    最近想提升,苦逼程序猿,想了想还是拿最熟悉,之前也一直想看但没看的spring源码来看吧,正好最近在弄事务这部分的东西,就看了下,同时写下随笔记录下,以备后查. spring tx源码分析 这里只分析 ...

  7. 使用工具intellij idea 进行java web开发简介

    一.工具下载及安装准备 1.首先下载工具  Intellij idea ,下载地址:https://www.jetbrains.com/ 2.破解 百度下载一个 JetbrainsCrack-2.7- ...

  8. IIS命令行静默安装脚本-python

    #coding=utf8 import platform from subprocess import Popen,PIPE,STDOUT import sys,os def run_cmd(cmd, ...

  9. ubuntu 16.04扩充root 分区

    ubuntu使用过程中,提示root分区剩余空间不足,剩余200多M时还可以进行一些操作,剩余几M时拷贝等命令都不能够执行. 扩充root分区步骤如下: 1.查看root分区所在位置: 命令: sud ...

  10. zabbix3.2使用fping批量监控ip的连通性

    .在zabbix-agent端安装fping wget http://www.fping.org/dist/fping-3.16.tar.gz tar zxvf fping-3.16.tar.gz c ...