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\ ...
随机推荐
- WPF 导出Excel 导出图片
/// <summary> /// 导出Excel /// </summary> private void ExportExcel(DataTable ExcelDt) { / ...
- windows下和linux下运行jar
需要在windows下运行jar,首先需要我们打包出来可执行jar idea打包可执行jar可以参考我的另一篇博客[https://mp.csdn.net/postedit/88653200] 一.w ...
- NOIP2017普及组翻车记
我就是一个这么个人:平常训练好好的,一到考场就炸. 不管是NOIP还是考试都是这样. 比赛时我脑抽,第二题相减后,居然一点一点地模10. 后来觉得很慢,用近乎一个小时时间,打了另一个方法(不是字典树, ...
- EasyUI Tree与Datagrid联动
效果图 这是一个简单的solr检索的例子 输入关键词,显示树 选择一个节点,得到该节点下文档信息 代码: JSP: 重点是标红的URL传递 <body> <d ...
- c++ 读取8, 10, 16进制数
c++基础知识都快忘了..记一下 dec-十进制(默认) oct-八进制 hex-十六进制
- windows下docker 启动jenkins成功,浏览器无法访问,拒绝了我们的连接
[问题现象] 在Windows下使用docker启动了一个jenkins,翻越了无数的坑,最后的启动命令为 docker run --name jenkins -u root -p 8000:8000 ...
- python intern(字符串驻留机制)
python 中为了提高字符串的使用用效率和节约内存,对于由 字母.数字.下划线组成的标识符采用了 intern 机制,即对于短字符串,将其赋值给多个对象时,内存中只有一个副本,多个对象共享这个副本. ...
- sqlserver数据往别的数据库迁移
背景:sqlserver数据库数据是服务于一个.net项目.后来由于去.net 要将数据前往高斯数据库 或者Oracle. 问题是 当sql Name Age Gender from student ...
- JDK8日期时间操作小汇总
统一使用java.time.*包下的类 1.获取当前的日期.时间.日期加时间 LocalDate todayDate = LocalDate.now(); //今天的日期 LocalTime now ...
- loj2324 「清华集训 2017」小 Y 和二叉树
https://loj.ac/problem/2324 太智障,一开始以为中序遍历的第一个点一定是一个叶子,想了个贪心.然而,手算了一下,第一个点都过不了啊. input 5 2 3 4 1 3 3 ...