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\ ...
随机推荐
- [转]基于MefBootstrapper的Bootstrapper
public class Bootstrapper : MefBootstrapper { ModuleCatalog moduleCatalog; protected overr ...
- Java实现对日期上旬中旬下旬格式化
PS:我数据库表定义的日期是String类型,要求对读取的日期进行格式化为xx年xx月上\中\下旬 测试代码如下 package day1; import java.text.ParseExcepti ...
- 出现大量rcuob进程
方法一: vim /etc/default/grub,在GRUB_CMDLINE_LINUX这一行末尾添加nr_cpus=2,然后执行命令grub2-mkconfig -o /boot/grub2/g ...
- 移动端iPhone系列适配问题
问题一:苹果手机上的input按钮自带渐变效果 一样的代码,为啥在苹果手机上的input按钮就自带渐变效果,搞特殊吗?怎么让它显示正常?只需要加上outline:0px; -webkit-appear ...
- Cesium打包命令总结
引言 Cesium实验室QQ群里有人在问Cesium的打包问题.我想干脆总结一下Cesium的打包命令特点,写篇文章,顺带庆祝一下1024程序员节.. Cesium的npm脚本有好多,其中几个和打包相 ...
- 关于解码芯片SAA7115及7105的配置 ,FVID与微驱动
最近因为在做视频处理,所以和解码芯片打交道很多,根据DM642的例程总了一些应该配置的东西. 注:以下的配置均是指AV信号输入,PAL制式输出的条件 (一)关于SAA7115(基于TI的驱动) 结构体 ...
- 2019.10.28 csp-s模拟测试91 反思总结
有一场没一场的233 T1: 胡乱分析一下题意,发现和为n的x个正整数,不同的数字种类不会超过√n个.假设这x个数字都不同,最多也就是(x+1)*x/2=n. 所以可以维护现有的size值以及对应的数 ...
- workbench使用
1.你是指默认的mysql目录下data里面的'mysql'这个schema没有在workbench里面看到吧?点击菜单-Edit->Preferences里面的SQL Editor,然后把&q ...
- stream求集合元素的属性值最值
Person p1 = new Person("张三", new BigDecimal("10.0"));Person p2 = new Person(&quo ...
- json字符串和对象的相互转换
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式. 同时,JSON是 JavaScript 原生格式,这 ...