bzoj3196:Tyvj1730二逼平衡树
传送门
暴力啊,直接树套树上啊
线段树套splay,卡卡常就直接A了
代码:
#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
void read(int &x) {
char ch; bool ok;
for(ok=0,ch=getchar(); !isdigit(ch); ch=getchar()) if(ch=='-') ok=1;
for(x=0; isdigit(ch); x=x*10+ch-'0',ch=getchar()); if(ok) x=-x;
}
void print(int x){
if(x<0)putchar('-'),x=-x;
if(x>9)print(x/10);
putchar(x%10+'0');
}
#define rg register
const int maxn=5e4+10;
int n,m,a[maxn],cnt[maxn*30],size[maxn*30],ch[maxn*30][2],rt[maxn*4],f[maxn*30],id,v[maxn*30],tot;
struct splay_tree
{
void update(int x){size[x]=size[ch[x][0]]+size[ch[x][1]]+cnt[x];}
void move(int &k,int x)
{
int tmp=ch[f[x]][1]==x,fa=f[x],faa=f[fa];
if(k==fa)k=x;
else ch[faa][ch[faa][1]==fa]=x;
ch[fa][tmp]=ch[x][tmp^1];f[ch[x][tmp^1]]=fa;
ch[x][tmp^1]=fa,f[x]=faa,f[fa]=x;
update(fa),update(x);
}
void splay(int &k,int x)
{
while(k!=x)
{
int y=f[x],z=f[y];
if(y!=k)
{
if((ch[y][0]==x)^(ch[z][0]==y))move(k,y);
else move(k,x);
}
move(k,x);
}
}
int get_pre(int k)
{
int now=ch[rt[k]][0];
while(ch[now][1])now=ch[now][1];
return now;
}
void del(int k,int x)
{
splay(rt[k],x);
if(!ch[x][0]&&!ch[x][1]){rt[k]=0;return ;}
else if(!ch[x][0]&&ch[x][1]){rt[k]=ch[x][1],f[rt[k]]=0;return ;}
else if(ch[x][0]&&!ch[x][1]){rt[k]=ch[x][0],f[rt[k]]=0;return ;}
int g=get_pre(k);splay(rt[k],g);
ch[g][1]=ch[x][1],f[ch[x][1]]=g;update(g);
}
void insert(int z,int x,int y)
{
if(!rt[z]){rt[z]=++id,v[rt[z]]=x,size[rt[z]]=cnt[rt[z]]=1;return ;}
int now=rt[z];
while(1)
{
if(x==v[now]){cnt[now]+=y,update(now);if(!cnt[now])del(z,now);else splay(rt[z],now);return ;}
else if(x<v[now])
{
if(!ch[now][0])
{
ch[now][0]=++id,size[id]=cnt[id]=1;
v[id]=x,f[id]=now;
update(now);break;
}
else now=ch[now][0];
}
else
{
if(!ch[now][1])
{
ch[now][1]=++id,size[id]=cnt[id]=1;
v[id]=x,f[id]=now;
update(now);break;
}
else now=ch[now][1];
}
}
splay(rt[z],id);
}
int findmn(int k,int x)
{
if(!k||!x)return 0;
if(v[k]==x)return size[ch[k][0]];
if(v[k]>x)return findmn(ch[k][0],x);
return size[ch[k][0]]+cnt[k]+findmn(ch[k][1],x);
}
int findmx(int k,int x)
{
if(!k||!x)return 0;
if(v[k]==x)return size[ch[k][0]]+cnt[k];
if(v[k]>x)return findmx(ch[k][0],x);
return size[ch[k][0]]+cnt[k]+findmx(ch[k][1],x);
}
int find(int k,int x)
{
if(!k)return 0;
if(x<=size[ch[k][0]])return find(ch[k][0],x);
if(x>size[ch[k][0]]&&x<=size[ch[k][0]]+cnt[k])return v[k];
return find(ch[k][1],x-size[ch[k][0]]-cnt[k]);
}
int pre(int k,int x)
{
int tmp=find(rt[k],findmn(rt[k],x));
return tmp?tmp:-2147483647;
}
int nxt(int k,int x)
{
int tmp=find(rt[k],findmx(rt[k],x)+1);
return tmp?tmp:2147483647;
}
}s[maxn*4];
void change(int x,int l,int r,int a,int b,int c)
{
s[x].insert(x,b,c);
if(l==r)return ;int mid=(l+r)>>1;
if(a<=mid)change(x<<1,l,mid,a,b,c);
else change(x<<1|1,mid+1,r,a,b,c);
}
int query(int x,int l,int r,int a,int b,int c)
{
if(a<=l&&b>=r)return s[x].findmn(rt[x],c);
int mid=(l+r)>>1,ans=0;
if(a<=mid)ans+=query(x<<1,l,mid,a,b,c);
if(b>mid)ans+=query(x<<1|1,mid+1,r,a,b,c);
return ans;
}
int find_pre(int x,int l,int r,int a,int b,int c)
{
if(a<=l&&b>=r){return s[x].pre(x,c);}
int mid=(l+r)>>1,ans=-2147483647;
if(a<=mid)ans=max(ans,find_pre(x<<1,l,mid,a,b,c));
if(b>mid)ans=max(ans,find_pre(x<<1|1,mid+1,r,a,b,c));
return ans;
}
int find_nxt(int x,int l,int r,int a,int b,int c)
{
if(a<=l&&b>=r){return s[x].nxt(x,c);}
int mid=(l+r)>>1,ans=2147483647;
if(a<=mid)ans=min(ans,find_nxt(x<<1,l,mid,a,b,c));
if(b>mid)ans=min(ans,find_nxt(x<<1|1,mid+1,r,a,b,c));
return ans;
}
bool check(int x,int y,int z,int k){return query(1,1,n,y,z,x)+1<=k;}
int main()
{
read(n),read(m);
for(rg int i=1;i<=n;i++)read(a[i]),change(1,1,n,i,a[i],1);
for(rg int i=1,opt,x,y,z;i<=m;i++)
{
read(opt),read(x),read(y);
if(opt==1)read(z),print(query(1,1,n,x,y,z)+1),puts("");
if(opt==2)
{
read(z);int l=0,r=1e8;
while(l<=r)
{
int mid=(l+r)>>1;
if(check(mid,x,y,z))l=mid+1;
else r=mid-1;
}
print(r);puts("");
}
if(opt==3)change(1,1,n,x,a[x],-1),a[x]=y,change(1,1,n,x,a[x],1);
if(opt==4)read(z),print(find_pre(1,1,n,x,y,z)),puts("");
if(opt==5)read(z),print(find_nxt(1,1,n,x,y,z)),puts("");
}
}
bzoj3196:Tyvj1730二逼平衡树的更多相关文章
- BZOJ3196 Tyvj1730 二逼平衡树 【树套树】 【线段树套treap】
BZOJ3196 Tyvj1730 二逼平衡树 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排名 2.查询区间内排名 ...
- [BZOJ3196][Tyvj1730]二逼平衡树
[BZOJ3196][Tyvj1730]二逼平衡树 试题描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 查询 \(k\) 在区间内的排名 查询区间内排名为 \ ...
- [bzoj3196][Tyvj1730]二逼平衡树_树套树_位置线段树套非旋转Treap/树状数组套主席树/权值线段树套位置线段树
二逼平衡树 bzoj-3196 Tyvj-1730 题目大意:请写出一个维护序列的数据结构支持:查询给定权值排名:查询区间k小值:单点修改:查询区间内定值前驱:查询区间内定值后继. 注释:$1\le ...
- bzoj3196 [TYVJ1730]二逼平衡树 树套树 线段树套替罪羊树
人傻自带大常数 二分的可行性证明: 贴近他的正确答案不会被当作次优解删掉,因为,若二分在他右边发生,那么二分一定会把左边作为优解,左边同理,所以他一定是被扣掉的所以最后一个小于等于一定是正确答案 #i ...
- [BZOJ3196] [Tyvj1730] 二逼平衡树(线段树 套 Splay)
传送门 至少BZOJ过了,其他的直接弃. 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排名 2.查询区间内排名为k的值 3.修改某一位值上的 ...
- 【BZOJ3196】二逼平衡树(树状数组,线段树)
[BZOJ3196]二逼平衡树(树状数组,线段树) 题面 BZOJ题面 题解 如果不存在区间修改操作: 搞一个权值线段树 区间第K大--->直接在线段树上二分 某个数第几大--->查询一下 ...
- [TYVJ1730]二逼平衡树
[TYVJ1730]二逼平衡树 题目 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:1.查询k在区间内的排名2.查询区间内排名为k的值3.修改某一位值上的数值4.查 ...
- 【BZOJ-3196】二逼平衡树 线段树 + Splay (线段树套平衡树)
3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2271 Solved: 935[Submit][Stat ...
- 【bzoj3196】 Tyvj1730—二逼平衡树
http://www.lydsy.com/JudgeOnline/problem.php?id=3196 (题目链接) 题意 1.查询k在区间内的排名:2.查询区间内排名为k的值:3.修改某一位值上的 ...
随机推荐
- 一起来学linux:磁盘与文件系统:
对于文件系统来说,windows上最长用的就是FAT32和NTFS.在Linux上时候用的是Ext2.在linux中,文件权限与文件属性这两部分会被存储在不同的块,权限与权限放置到inode中,实际数 ...
- jQuery param()作用与使用方法
$.param()方法是serialize()方法的核心,用来对一个数组或对象按照key/value进行序列化. $.param(obj) 返回 :string: 说明:将jquery对象按照name ...
- POSTGRESQL主备部署模式
一.预期目的 主数据库(Primary pg ,假定主机名为A,后文不再赘述)和备用数据库(Standby pg,假定主机名为B,后文不再赘述)之间的数据能够相互备份. 主数据库发生故障时备用数据库可 ...
- 物体position:absolute后设置left:50%发生的有趣小事
今天在重构ui控件中3秒hint提示框样式,发现了一个有趣的小事,特发个文章记录一下,方便自己日后看一下 一 准备知识 ①一个已设置宽高的块状元素设置position:absolute后会保持他原来宽 ...
- (转)Java经典设计模式(3):十一种行为型模式(附实例和详解)
原文出处: 小宝鸽 Java经典设计模式共有21中,分为三大类:创建型模式(5种).结构型模式(7种)和行为型模式(11种). 本文主要讲行为型模式,创建型模式和结构型模式可以看博主的另外两篇文章:J ...
- php字符串啊的heredoc格式
Heredoc技术,在正规的PHP文档中和技术书籍中一般没有详细讲述,只是提到了这是一种Perl风格的字符串输出技术.它也出现unix/linux的shell编程里面.但是现在的一些论坛程序,和部分文 ...
- Spring MVC 注解开发详解
@Controller控制器定义 1.Controller是单利模式,被多个线程请求共享,因此设计成无序状态. 2.通过@controller标注即可将class定义为一个controller类.为使 ...
- 日志的打印 —— Java 支持
1. java.util.logging.Logger 日志级别(logLevel) OFF,Integer.MAX_VALUE SEVERE,1000 WARNING,900 INFO,800 CO ...
- MFC中显示一张位图
1.用类CBitmap加载位图 2.创建内存DC, 将位图选进此内存DC 3.调用BitBlt将内存DC的内容拷贝到其它DC(通知是显示DC) 例子(来自MSDN): // This OnDraw() ...
- ubuntu下安装显卡驱动
前言 以下内容是个人学习之后的感悟,转载请注明出处~ 作者的显卡是GT 730,现以NVIDIA-Linux-x86-384.69为例. 1.打开终端,先删除旧的驱动: sudo ...