【bzoj3685】普通van Emde Boas树 线段树
2024-10-21 09:10:32
普通van Emde Boas树
Time Limit: 9 Sec Memory Limit: 128 MB
Submit: 1969 Solved: 639
[Submit][Status][Discuss]
Description
设计数据结构支持:
1 x 若x不存在,插入x
2 x 若x存在,删除x
3 输出当前最小值,若不存在输出-1
4 输出当前最大值,若不存在输出-1
5 x 输出x的前驱,若不存在输出-1
6 x 输出x的后继,若不存在输出-1
7 x 若x存在,输出1,否则输出-1
Input
第一行给出n,m 表示出现数的范围和操作个数
接下来m行给出操作
n<=10^6,m<=2*10^6,0<=x<n
Output
Sample Input
10 11
1 1
1 2
1 3
7 1
7 4
2 1
3
2 3
4
5 3
6 2
1 1
1 2
1 3
7 1
7 4
2 1
3
2 3
4
5 3
6 2
Sample Output
1
-1
2
2
2
-1
-1
2
2
2
-1
HINT
Source
题解:
很多数据结构都可以解决。
权值线段树就可以。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath> #define N 3000007 using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
} int n,m;
struct seg
{
int l,r,v;
}t[N]; void build(int k,int l,int r)
{
t[k].l=l;t[k].r=r;
if(l==r)return;
int mid=(l+r)>>;
build(k<<,l,mid);
build(k<<|,mid+,r);
}
int mn(int k)
{
if(!t[k].v)return -;
int l=t[k].l,r=t[k].r;
if(l==r)return l;
if(t[k<<].v)return mn(k<<);
else return mn(k<<|);
}
int mx(int k)
{
if(!t[k].v)return -;
int l=t[k].l,r=t[k].r;
if(l==r)return l;
if(t[k<<|].v)return mx(k<<|);
else return mx(k<<);
}
void insert(int k,int val)
{
int l=t[k].l,r=t[k].r;
if(l==r){t[k].v=;return;}
int mid=(l+r)>>;
if(val<=mid)insert(k<<,val);
else insert(k<<|,val);
t[k].v=t[k<<].v+t[k<<|].v;
}
int find(int k,int val)
{
int l=t[k].l,r=t[k].r;
if(l==r)
{
if(t[k].v)return ;
return -;
}
int mid=(l+r)>>;
if(val<=mid)return find(k<<,val);
else return find(k<<|,val);
}
void del(int k,int val)
{
int l=t[k].l,r=t[k].r;
if(l==r){t[k].v=;return;}
int mid=(l+r)>>;
if(val<=mid)del(k<<,val);
else del(k<<|,val);
t[k].v=t[k<<].v+t[k<<|].v;
}
int findpr(int k,int val)
{
if(val<)return -;
if(!t[k].v)return -;
int l=t[k].l,r=t[k].r;
if(l==r)return l;
int mid=(l+r)>>;
if(val<=mid)return findpr(k<<,val);
else
{
int t=findpr(k<<|,val);
if(t==-)return mx(k<<);
else return t;
}
}
int findsu(int k,int val)
{
if(!t[k].v)return -;
int l=t[k].l,r=t[k].r;
if(l==r)return l;
int mid=(l+r)>>;
if(val>mid)return findsu(k<<|,val);
else
{
int t=findsu(k<<,val);
if(t==-)return mn(k<<|);
else return t;
}
}
int main()
{
n=read(),m=read();
build(,,n);
int opt,x;
for(int i=;i<=m;i++)
{
opt=read();
switch(opt)
{
case :x=read();if(find(,x)==-)insert(,x);break;
case :x=read();if(find(,x)==)del(,x);break;
case :printf("%d\n",mn());break;
case :printf("%d\n",mx());break;
case :x=read();printf("%d\n",findpr(,x-));break;
case :x=read();printf("%d\n",findsu(,x+));break;
case :x=read();printf("%d\n",find(,x));break;
}
}
}
最新文章
- kali安装vmtools问题
- linux和windows共享文件
- c++ 的vector
- Android: 触屏fling/scroll/drag的区别及其详细过程
- CSS3- px、em、rem区别介绍
- Competitive
- docker Swarm 集群发现
- Lucene4.X 高级应用
- java 创建一个File文件对象
- 工作总结之Git
- IIS 500错误或无法显示此网页解决方法
- try{}里有一个 return 语句,那么紧跟在这个 try 后的 finally {}里的 code 会 不会被执行,什么时候被执行,在 return 前还是后?
- 在python里调用java的py4j的使用方法
- Node.JS 项目打包 JXCore
- :复合模式:duck
- JMeter采用NON GUI模式时如何记录并查看错误
- Linux内核分析——第二章 从内核出发
- 使用Laya引擎开发微信小游戏
- 深入理解yield(二):yield与协程
- mysql - 在已有真实数据的表的基础上加入自增主键
热门文章
- PAT (Advanced Level) Practise - 1093. Count PAT&#39;s (25)
- java设计模式——单例模式(三)
- C++ 无限定名称查找
- mysql update 多表关联更新
- 5.Cisco Packet Tracer里关于交换机或路由器配置文件和系统映像备份与恢复
- 分数调查 HihoCoder - 1515
- 江西理工大学编程俱乐部 2328 Star
- billard:桌球的走位路线图解
- 驱动模块 .ko
- Js中的undefined和not defined