BZOJ2770: YY的Treap
原本看标题还以为是treap的题,但是实际上是线段树。
求两点的LCA相当于求区间priority最小值的位置。
然后就可以离线先离散化然后建树做了。
记录的minpos是线段树上叶子结点的节点编号。
一道水题。
//Serene
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<set>
using namespace std;
const long long maxn=1e5+10,maxm=3e5+10,INF=1e18;
long long n,m;
long long pp[maxn],pr[maxn],rr[maxm],rp[maxm];
char kk[maxm];
long long num[maxn+maxm],tot=0; set<long long> G;
set<long long>::iterator it; long long aa,ff;char cc;
long long read() {
aa=0;ff=1;cc=getchar();
while((cc<'0'||cc>'9')&&cc!='-') cc=getchar();
if(cc=='-') ff=-1,cc=getchar();
while(cc>='0'&&cc<='9') aa=aa*10+cc-'0',cc=getchar();
return aa*ff;
} struct Node{
int l,r,minpos;long long minnum;
}node[4*(maxn+maxm)]; void bld(int pos,int l,int r) {
node[pos].l=l;node[pos].r=r;
node[pos].minnum=INF;
if(l==r) {
node[pos].minpos=pos;
return;
}
int mid=(l+r)>>1;
bld(pos<<1,l,mid);
bld(pos<<1|1,mid+1,r);
node[pos].minpos=node[pos<<1].minpos;
} void chge(int pos,int os,long long prr) {
if(node[pos].l==node[pos].r) {
node[pos].minnum=prr;
node[pos].minpos=pos;
return ;
}
int mid=(node[pos].l+node[pos].r)>>1;
if(os<=mid) chge(pos<<1,os,prr);
else chge(pos<<1|1,os,prr);
node[pos].minnum=min(node[pos<<1].minnum,node[pos<<1|1].minnum);
node[pos].minpos= node[pos<<1].minnum<node[pos<<1|1].minnum? node[pos<<1].minpos:node[pos<<1|1].minpos;
} int ef(int l,int r,long long key) {
if(l>=r-1) return l;
int mid=(l+r)>>1;
if(num[mid]==key) return mid;
if(num[mid]>key) return ef(l,mid,key);
return ef(mid+1,r,key);
} int q(int pos,int l,int r) {
if(l>r) swap(l,r);
if(node[pos].l==l&&node[pos].r==r) return node[pos].minpos;
int mid=(node[pos].l+node[pos].r)>>1;
if(l>mid) return q(pos<<1|1,l,r);
if(r<=mid) return q(pos<<1,l,r);
int ans1=q(pos<<1,l,mid),ans2=q(pos<<1|1,mid+1,r);
return node[ans1].minnum<node[ans2].minnum? ans1:ans2;
} int main() {
n=read();m=read();
for(int i=1;i<=n;++i) {
pp[i]=read();
G.insert(pp[i]);
}
for(int i=1;i<=n;++i) pr[i]=read();
for(int i=1;i<=m;++i) {
kk[i]=getchar();
while(kk[i]<'A'||kk[i]>'Z') kk[i]=getchar();
rr[i]=read();
if(kk[i]!='D') rp[i]=read();
if(kk[i]=='I') G.insert(rr[i]);
}
for(it=G.begin();it!=G.end();++it) num[++tot]=*it;
bld(1,1,tot);
for(int i=1;i<=n;++i) chge(1,ef(1,tot+1,pp[i]),pr[i]);
for(int i=1;i<=m;++i) {
if(kk[i]=='I') chge(1,ef(1,tot+1,rr[i]),rp[i]);
else if(kk[i]=='D') chge(1,ef(1,tot+1,rr[i]),INF);
else printf("%lld\n",num[node[q(1,ef(1,tot+1,rr[i]),ef(1,tot+1,rp[i]))].l]);
}
return 0;
}
BZOJ2770: YY的Treap的更多相关文章
- 【BZOJ2770】YY的Treap 结论+线段树
[BZOJ2770]YY的Treap Description 志向远大的YY小朋友在学完快速排序之后决定学习平衡树,左思右想再加上SY的教唆,YY决定学习Treap.友爱教教父SY如砍瓜切菜般教会了Y ...
- 【bzoj2770】YY的Treap 权值线段树
题目描述 志向远大的YY小朋友在学完快速排序之后决定学习平衡树,左思右想再加上SY的教唆,YY决定学习Treap.友爱教教父SY如砍瓜切菜般教会了YY小朋友Treap(一种平衡树,通过对每个节点随机分 ...
- bzoj 2770 YY的Treap
Written with StackEdit. Description 志向远大的\(YY\)小朋友在学完快速排序之后决定学习平衡树,左思右想再加上\(SY\)的教唆,\(YY\)决定学习\(Trea ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- Treap初步
模板题 bzoj3224: Tyvj 1728 普通平衡树 #include <bits/stdc++.h> #define rep(i, a, b) for (int i = a; i ...
- 「FHQ Treap」学习笔记
话说天下大事,就像fhq treap —— 分久必合,合久必分 简单讲一讲.非旋treap主要依靠分裂和合并来实现操作.(递归,不维护fa不维护cnt) 合并的前提是两棵树的权值满足一边的最大的比另一 ...
- 非旋 treap 结构体数组版(无指针)详解,有图有真相
非旋 $treap$ (FHQ treap)的简单入门 前置技能 建议在掌握普通 treap 以及 左偏堆(也就是可并堆)食用本blog 原理 以随机数维护平衡,使树高期望为logn级别, FHQ ...
- 【BZOJ1112】[POI2008]砖块Klo Treap
[BZOJ1112][POI2008]砖块Klo Description N柱砖,希望有连续K柱的高度是一样的. 你可以选择以下两个动作 1:从某柱砖的顶端拿一块砖出来,丢掉不要了. 2:从仓库中拿出 ...
- #503. 「LibreOJ β Round」ZQC 的课堂 容斥原理+Treap
题目: 题解: 比较容易发现 : \(x,y\) 的贡献是独立的. 所以可以分开考虑. 假设我们考虑 \(x\).向量在 \(x\) 方向的投影依次是 : \(\{a_1,a_2, ... ,a_n\ ...
随机推荐
- linux 显示ip地址小工具-nali
1.下载软件包 wget http://qqwry.googlecode.com/files/nali-0.1.tar.gz 2.安装 tar -zxvf nali-0.2.tar.gz cd nal ...
- Ionic cordova-plugin-splashscreen
1.添加插件 cordova plugin add https://github.com/apache/cordova-plugin-splashscreen.git 2.设置启动画面 在根目录下面r ...
- ACM中Java使用注意事项
1. String 类用来存储字符串,可以用charAt方法来取出其中某一字节,计数从0开始, 而不是像C/C++那样使用 []访问是每个字符. 2. 在主类中 main 方法必须是 public s ...
- Intelij Idea 2016破解
在注册时选择License server,输入http://www.iteblog.com/idea/key.php,点击OK
- android服务的bindService/startService
1,高版本android已经不允许只通过action来bindService/startService,可以通过: intent.setPackage("XXXX"); 来指定服务 ...
- c++容器中map的应用
原文链接:https://www.cnblogs.com/fnlingnzb-learner/p/5833051.html Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关 ...
- Python数据分析入门与实践
Python数据分析入门与实践 整个课程都看完了,这个课程的分享可以往下看,下面有链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感受,单论单个知识点课程本身没问题,大家看的时候可以关 ...
- Python-Jsonpath简单入门
原文来自:http://goessner.net/articles/JsonPath/ JSONPath - 是xpath在json的应用. xml最大的优点就有大量的工具可以分析,转换,和选择性 ...
- Eureka客户端无法连接服务注册中心
转载自:https://my.oschina.net/kousm/blog/2249003 服务端 application.yml配置 spring: application: name: eurek ...
- Luogu P1312 Mayan游戏(搜索)
P1312 Mayan游戏 题意 题目描述 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个\(7\)行\(\times 5\)列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必 ...