2018.08.04 洛谷P3380 【模板】二逼平衡树(树套树)
传送门
技不如人,写的权值线段树套线段树在bzoj上无论如何都卡不过空间。
这是一道树套树简单题,感觉没什么好说的。
直接权值线段树套平衡树就行了。
代码:
#include<bits/stdc++.h>
#define N 200000000
using namespace std;
int n,m,t1,t2,t3,t4;
int siz[30000005],son[30000005][2],intot,outtot,val[8000005],ch[8000005][2],rt[8000005],RT;
inline void pushup_in(int p){siz[p]=siz[son[p][0]]+siz[son[p][1]];}
inline void update_in(int&p,int l,int r,int k,int v){
if(!p)p=++intot;
if(l==r){siz[p]+=v;return;}
int mid=l+r>>1;
if(k<=mid)update_in(son[p][0],l,mid,k,v);
else update_in(son[p][1],mid+1,r,k,v);
pushup_in(p);
}
inline int query_in(int p,int l,int r,int ql,int qr){
if(ql>r||qr<l)return 0;
if(ql<=l&&r<=qr)return siz[p];
int mid=l+r>>1;
return query_in(son[p][0],l,mid,ql,qr)+query_in(son[p][1],mid+1,r,ql,qr);
}
inline void update_out(int&p,int l,int r,int outk,int ink,int v){
if(!p)p=++outtot;
update_in(rt[p],1,n,ink,v);
if(l==r)return;
int mid=l+r>>1;
if(outk<=mid)update_out(ch[p][0],l,mid,outk,ink,v);
else update_out(ch[p][1],mid+1,r,outk,ink,v);
}
inline int query_out(int p,int l,int r,int oql,int oqr,int iql,int iqr){
if(oql>r||oqr<l||!p)return 0;
if(oql<=l&&r<=oqr)return query_in(rt[p],1,n,iql,iqr);
int mid=l+r>>1;
return query_out(ch[p][0],l,mid,oql,oqr,iql,iqr)+query_out(ch[p][1],mid+1,r,oql,oqr,iql,iqr);
}
inline int kth(int p,int l,int r,int k,int ql,int qr){
if(l==r)return l;
int tmp=query_in(rt[ch[p][0]],1,n,ql,qr),mid=l+r>>1;
if(tmp>=k)return kth(ch[p][0],l,mid,k,ql,qr);
return kth(ch[p][1],mid+1,r,k-tmp,ql,qr);
}
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i){
scanf("%d",&val[i]);
update_out(RT,1,N,val[i]+1,i,1);
}
while(m--){
int op,a,b,c;
scanf("%d%d%d",&op,&a,&b);
if(op==3){update_out(RT,1,N,val[a]+1,a,-1),update_out(RT,1,N,1+(val[a]=b),a,1);continue;}
scanf("%d",&c);
if(op==1){printf("%d\n",query_out(RT,1,N,1,c,a,b)+1);}
else if(op==2){printf("%d\n",kth(RT,1,N,c,a,b)-1);}
else if(op==4){
int tmp=query_out(RT,1,N,1,c,a,b);
if(tmp)printf("%d\n",kth(RT,1,N,tmp,a,b)-1);
else puts("-2147483647");
}
else if(op==5){
int tmp=query_out(RT,1,N,1,c+1,a,b)+1;
if((b-a+1)<tmp)puts("2147483647");
else printf("%d\n",kth(RT,1,N,tmp,a,b)-1);
}
}
return 0;
}
2018.08.04 洛谷P3380 【模板】二逼平衡树(树套树)的更多相关文章
- BZOJ3196 & 洛谷3380:二逼平衡树——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=3196 https://www.luogu.org/problemnew/show/P3380 (题 ...
- 2018.08.11 洛谷P3224 [HNOI2012]永无乡(线段树合并)
传送门 给出n个带点权的点,支持连边和查询连通块第k大. 这个貌似就是一道线段树合并的裸板啊... 代码: #include<bits/stdc++.h> #define N 100005 ...
- 2018.07.01洛谷P2617 Dynamic Rankings(带修主席树)
P2617 Dynamic Rankings 题目描述 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1],a[i ...
- bzoj 3196 Tyvj 1730 二逼平衡树(线段树套名次树)
3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1807 Solved: 772[Submit][Stat ...
- bzoj 3196/ Tyvj 1730 二逼平衡树 (线段树套平衡树)
3196: Tyvj 1730 二逼平衡树 Time Limit: 10 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description ...
- 2018.08.28 洛谷P3803 【模板】多项式乘法(FFT)
传送门 fft模板题. 终于学会fft了. 这个方法真是神奇! 经过试验发现手写的complex快得多啊! 代码: #include<iostream> #include<cstdi ...
- 2018.08.16 洛谷P1437 [HNOI2004]敲砖块(二维dp)
传送门 看起来普通dp" role="presentation" style="position: relative;">dpdp像是有后效性的 ...
- 2018.11.04 洛谷P2679 子串(线性dp)
传送门 为什么前几年的noipnoipnoip总是出这种送分题啊? 这个直接线性dpdpdp不就完了吗? f[i][j][k][0/1]f[i][j][k][0/1]f[i][j][k][0/1]表示 ...
- 2018.11.04 洛谷P1081 开车旅行(倍增)
传送门 思路简单码量超凡? 感觉看完题大家应该都知道是倍增sbsbsb题了吧. 首先预处理出从每个点出发如果是AAA走到哪个点,如果是BBB走到哪个点. 然后利用刚刚预处理出的信息再预处理从每个点出发 ...
随机推荐
- XE4 TStringDynArray 比 c6 的TStringList 好用 字符串 分解 分割 转换 TByteDynArray
TStringDynArray 动态数组 字符串 分解 分割 System::DynamicArray<System::UnicodeString> TByteDynArray, ...
- MySQL 获取最后插入的ID LAST_INSERT_ID用法
LAST_INSERT_ID() 自动返回最后一个INSERT或 UPDATE 查询中 AUTO_INCREMENT列设置的第一个表发生的值. MySQL的LAST_INSERT_ID的注意事项: 第 ...
- Nexus使用
Nexus使用: Nexus的默认登录账户:admin,密码:admin123. 以下为步骤说明: 1.右上角->login 2.左菜单->security->user->ad ...
- UI5-文档-2.1-使用OpenUI5开发应用
使用OpenUI5和您选择的开发环境(编辑器和Web服务器)开发应用程序.您可以下载所有的源代码,也可以参考OpenUI5的在线版本. 下载OpenUI5 下载和安装OpenUI5的默认方式是从htt ...
- WP8.1 发送邮件
Method 1: Windows.System.Launcher.LaunchUriAsync(new Uri("abc@outlook.com?subject=hello world&a ...
- cmake编译参数
进入源码目录后 cmake . -LH --查看之前编译参数 ccmake . 使用cmake gui界面进行查看和编辑编译用到的参数 (推荐) 源码目录下 INSTALL-SOURCE 文件后面 ...
- shell中的条件判断以及与python中的对比
shell中比如比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示条件测试. 注意:这里的空格很重要.要确保方括号的空格. if ....; then ...
- unity Object-c交互
一.unity 调用 Object-c C/C++可以直接与Object-c交互,只要把文件后缀.m直接改成.mm,成为C/C++与Object-c混编文件.C#又可以调用C/C++方法,所以C#就是 ...
- 抽象类(abstract class)
package com.bjsxt.oop.abstractClass; //抽象类 public abstract class Animal { //因为父类的方法总是被重写 那就没写的必要了 但是 ...
- SQL获取分组后取某字段最大一条记录(求每个类别中最大的值的列表)
获取分组后取某字段最大一条记录 方法一:(效率最高) select * from test as a where typeindex = (select max(b.typeindex) from t ...