BZOJ 3196 Tyvj 1730 二逼平衡树 ——树状数组套主席树
【题目分析】
听说是树套树。(雾)
怒写树状数组套主席树,然后就Rank1了。23333
单点修改,区间查询+k大数查询=树状数组套主席树。
【代码】
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <set>
#include <map>
#include <string>
#include <algorithm>
#include <vector>
#include <iostream>
#include <queue>
using namespace std;
#define maxn 50005
#define mlog 20
int 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;
}
int n,m;
int rt[maxn<<1],a[maxn],b[maxn<<1],cnt=0,tot=0,sum,rnk,TMP;
int ls[maxn<<6],rs[maxn<<6],siz[maxn<<6];
int L[maxn],R[maxn],opt[maxn],x[maxn],y[maxn],z[maxn];
void ins(int o1,int & o2,int l,int r,int x,int f)
{
// printf("ins %d %d %d %d %d %d\n",o1,o2,l,r,x,f);
o2=++tot;
siz[o2]=siz[o1]+f;
if (l==r) return ;
int mid=(l+r)/2;
if (x<=mid) rs[o2]=rs[o1],ins(ls[o1],ls[o2],l,mid,x,f);
else ls[o2]=ls[o1],ins(rs[o1],rs[o2],mid+1,r,x,f);
return ;
}
void ready(int l,int r)
{
// cout<<"ready for "<<l<<" "<<r<<endl;
l--;
L[0]=R[0]=0;
for (int j=l;j;j-=j&(-j)) L[++L[0]]=rt[j];
for (int j=r;j;j-=j&(-j)) R[++R[0]]=rt[j];
// cout<<"L "; for (int j=1;j<=L[0];++j) cout<<L[j]<<" "; cout<<endl;
// cout<<"R "; for (int j=1;j<=R[0];++j) cout<<R[j]<<" "; cout<<endl;
// cout<<"L "; for (int j=1;j<=L[0];++j) cout<<siz[L[j]]<<" "; cout<<endl;
// cout<<"R "; for (int j=1;j<=R[0];++j) cout<<siz[R[j]]<<" "; cout<<endl;
}
void cholef()
{
// cout<<"choose left"<<endl;
for (int i=1;i<=L[0];++i) L[i]=ls[L[i]];
for (int i=1;i<=R[0];++i) R[i]=ls[R[i]];
}
void chorig()
{
// cout<<"choose right"<<endl;
for (int i=1;i<=L[0];++i) L[i]=rs[L[i]];
for (int i=1;i<=R[0];++i) R[i]=rs[R[i]];
}
int taksum()
{
int ret=0;
for (int i=1;i<=L[0];++i) ret-=siz[ls[L[i]]];
for (int i=1;i<=R[0];++i) ret+=siz[ls[R[i]]];
return ret;
}
int qrnk(int l,int r,int x)
{
// printf("qrnk %d %d %d\n",l,r,x);
if (l==r) return 1;
int mid=(l+r)/2,tmp=taksum();
// cout<<"take sum "<<tmp<<endl;
if (x<=mid) return cholef(),qrnk(l,mid,x);
else return chorig(),tmp+qrnk(mid+1,r,x);
}
int qnum(int l,int r,int x)
{
if (l==r) return l;
int mid=(l+r)/2,tmp=taksum();
if (x<=tmp) return cholef(),qnum(l,mid,x);
else return chorig(),qnum(mid+1,r,x-tmp);
}
int main()
{
n=read();m=read();
for (int i=1;i<=n;++i) scanf("%d",&a[i]),b[++cnt]=a[i];
for (int i=1;i<=m;++i)
{
scanf("%d%d%d",&opt[i],&x[i],&y[i]);
if (opt[i]!=3) scanf("%d",&z[i]);
if (opt[i]==3) b[++cnt]=y[i];
if (opt[i]==4||opt[i]==5) b[++cnt]=z[i];
}
sort(b+1,b+cnt+1);
cnt=unique(b+1,b+cnt+1)-b-1;
for (int i=1;i<=n;++i) a[i]=lower_bound(b+1,b+cnt+1,a[i])-b;
for (int i=1;i<=m;++i)
{
if (opt[i]==1||opt[i]==4||opt[i]==5)z[i]=lower_bound(b+1,b+cnt+1,z[i])-b;
if (opt[i]==3) y[i]=lower_bound(b+1,b+cnt+1,y[i])-b;
}
// cout<<endl<<endl;
// for (int i=1;i<=cnt;++i) cout<<i<<" ";cout<<endl;
// for (int i=1;i<=cnt;++i) cout<<b[i]<<" "; cout<<endl;
// for (int i=1;i<=m;++i) cout<<opt[i]<<" "<<x[i]<<" "<<y[i]<<" "<<z[i]<<endl;
// cout<<endl<<endl;
for (int i=1;i<=n;++i)
for (int j=i;j<=n;j+=j&(-j))
ins(rt[j],rt[j],1,cnt,a[i],1);
for (int i=1;i<=m;++i)
{
switch(opt[i])
{
case 1:
ready(x[i],y[i]);
printf("%d\n",qrnk(1,cnt,z[i]));
break;
case 3:
for (int j=x[i];j<=n;j+=j&(-j))
{
ins(rt[j],rt[j],1,cnt,a[x[i]],-1);
ins(rt[j],rt[j],1,cnt,y[i],1);
}
a[x[i]]=y[i];
break;
case 2:
ready(x[i],y[i]);
printf("%d\n",b[qnum(1,cnt,z[i])]);
break;
case 4:
ready(x[i],y[i]);
rnk=qrnk(1,cnt,z[i]);
// printf("rnk is %d\n",rnk);
ready(x[i],y[i]);
printf("%d\n",b[qnum(1,cnt,rnk-1)]);
break;
case 5:
ready(x[i],y[i]);
TMP=0;
TMP-=qrnk(1,cnt,z[i]);
ready(x[i],y[i]);
TMP+=qrnk(1,cnt,z[i]+1);
// printf("it s have %d\n",TMP);
ready(x[i],y[i]);
rnk=qrnk(1,cnt,z[i]);
ready(x[i],y[i]);
printf("%d\n",b[qnum(1,cnt,rnk+TMP)]);
}
}
}
BZOJ 3196 Tyvj 1730 二逼平衡树 ——树状数组套主席树的更多相关文章
- bzoj 3196 Tyvj 1730 二逼平衡树(线段树套名次树)
3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1807 Solved: 772[Submit][Stat ...
- BZOJ 3196: Tyvj 1730 二逼平衡树( 树套树 )
这道题做法应该很多吧.... 我用了线段树套treap.... -------------------------------------------------------------------- ...
- bzoj 3196/ Tyvj 1730 二逼平衡树 (线段树套平衡树)
3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description ...
- BZOJ - 3196 Tyvj 1730 二逼平衡树 (线段树套treap)
题目链接 区间线段树套treap,空间复杂度$O(nlogn)$,时间复杂度除了查询区间k大是$O(log^3n)$以外都是$O(log^2n)$的. (据说线段树套线段树.树状数组套线段树也能过?) ...
- 【BZOJ】3196: Tyvj 1730 二逼平衡树(区间第k小+树套树)
http://www.lydsy.com/JudgeOnline/problem.php?id=3196 Treap+树状数组 1WA1A,好伤心,本来是可以直接1A的,这次开始我并没有看题解,就写出 ...
- bzoj 3196: Tyvj 1730 二逼平衡树
#include<cstdio> #include<ctime> #include<cstdlib> #include<iostream> #defin ...
- BZOJ 3196 Tyvj 1730 二逼平衡树 树套树 线段树 treap
http://www.lydsy.com/JudgeOnline/problem.php?id=3196 http://hzwer.com/2734.html 线段树套treap,似乎splay也可以 ...
- BZOJ 3196 Tyvj 1730 二逼平衡树:线段树套splay
传送门 题意 给你一个长度为 $ n $ 有序数列 $ a $ ,进行 $ m $ 次操作,操作有如下几种: 查询 $ k $ 在区间 $ [l,r] $ 内的排名 查询区间 $ [l,r] $ 内排 ...
- bzoj 3196 Tyvj 1730 二逼平衡树【线段树 套 splay】
四舍五入就是个暴力. 对于线段树的每个区间都开一棵按权值排序的splay 对于第二个操作,二分一下,每次查询mid的排名,复杂度 $ O(nlog(n)^{3}) $ 其余的操作都是$ O(nlog( ...
随机推荐
- React Native 开发之 (01) 配置开发环境
一 React Native React Native 是由Facebook发布的开源框架,着力于提高多平台开发的开发效率 —— 仅需学习一次,编写任何平台.(Learn once, write an ...
- js 中的基本类型和引用类型的区别
js中的基本类型赋值之后,只有值相等的时候,二者才会相等,例如 var a='123'; var b=a; console.log(a===b); 返回的是true ,说明他们是相等的, 此时改变a ...
- ppt2013技术整理
1. 显示选择窗格 便于选择该页的所有元素.分组.隐藏与显示等. 位于:开始-编辑-选择-选择窗格 2. 显示动画窗格 便于调节页面中元素的动画状态. 位于:动画-高级动画-动画窗格 3. 绑定动画触 ...
- python学习笔记-(十四)进程&协程
一. 进程 1. 多进程multiprocessing multiprocessing包是Python中的多进程管理包,是一个跨平台版本的多进程模块.与threading.Thread类似,它可以利用 ...
- mysql命令总结
统计全库数据量: use information_schema; SELECT TABLE_NAME, (DATA_LENGTH) as DataM , (INDEX_LENGTH) as Index ...
- Angular.js实现折叠按钮的经典指令.
var expanderModule=angular.module('expanderModule',[]) expanderModule.directive('expander',function( ...
- logo
- thinkphp自定义标签库
thinkphp ~ php中 的类, 的成员变量, 本身是没有类型说明的, 那么我怎么知道它的类型呢? 或初始值呢? 通常在类定义中, 如果能给一个初始值的(对于已知简单类型的),最好给一个初始值, ...
- 微信"附近的人"新增商家公众号入驻功能
微信近日升级了“附近的人”,新增商家公众号(认证的服务号和有卡券功能的公众号)可自入驻,这是微信在推出卡券和微信wifi功能后,又一加强连接线下商户能力的功能. 微信在“附近的人”中 增加搜索商户功能 ...
- TCP/IP 和 Socket 的关系
要写网络程序就必须用Socket,这是程序员都知道的.而且,面试的时候,我们也会问对方会不会Socket编程?一般来说,很多人都会说,Socket编程基本就是listen,accept以及send,w ...