原本看标题还以为是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的更多相关文章

  1. 【BZOJ2770】YY的Treap 结论+线段树

    [BZOJ2770]YY的Treap Description 志向远大的YY小朋友在学完快速排序之后决定学习平衡树,左思右想再加上SY的教唆,YY决定学习Treap.友爱教教父SY如砍瓜切菜般教会了Y ...

  2. 【bzoj2770】YY的Treap 权值线段树

    题目描述 志向远大的YY小朋友在学完快速排序之后决定学习平衡树,左思右想再加上SY的教唆,YY决定学习Treap.友爱教教父SY如砍瓜切菜般教会了YY小朋友Treap(一种平衡树,通过对每个节点随机分 ...

  3. bzoj 2770 YY的Treap

    Written with StackEdit. Description 志向远大的\(YY\)小朋友在学完快速排序之后决定学习平衡树,左思右想再加上\(SY\)的教唆,\(YY\)决定学习\(Trea ...

  4. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  5. Treap初步

    模板题 bzoj3224: Tyvj 1728 普通平衡树 #include <bits/stdc++.h> #define rep(i, a, b) for (int i = a; i ...

  6. 「FHQ Treap」学习笔记

    话说天下大事,就像fhq treap —— 分久必合,合久必分 简单讲一讲.非旋treap主要依靠分裂和合并来实现操作.(递归,不维护fa不维护cnt) 合并的前提是两棵树的权值满足一边的最大的比另一 ...

  7. 非旋 treap 结构体数组版(无指针)详解,有图有真相

    非旋  $treap$ (FHQ treap)的简单入门 前置技能 建议在掌握普通 treap 以及 左偏堆(也就是可并堆)食用本blog 原理 以随机数维护平衡,使树高期望为logn级别, FHQ  ...

  8. 【BZOJ1112】[POI2008]砖块Klo Treap

    [BZOJ1112][POI2008]砖块Klo Description N柱砖,希望有连续K柱的高度是一样的. 你可以选择以下两个动作 1:从某柱砖的顶端拿一块砖出来,丢掉不要了. 2:从仓库中拿出 ...

  9. #503. 「LibreOJ β Round」ZQC 的课堂 容斥原理+Treap

    题目: 题解: 比较容易发现 : \(x,y\) 的贡献是独立的. 所以可以分开考虑. 假设我们考虑 \(x\).向量在 \(x\) 方向的投影依次是 : \(\{a_1,a_2, ... ,a_n\ ...

随机推荐

  1. windows API 第 18篇 FindFirstVolume FindNextVolume

    函数定义:Retrieves the name of a volume on a computer. FindFirstVolume is used to begin scanning the vol ...

  2. Vue基础知识梳理

    1. Vue 实例 1.1 创建一个Vue实例 一个 Vue 应用由一个通过 new Vue 创建的根 Vue 实例,以及可选的嵌套的.可复用的组件树组成.demo 1.2 数据与方法 数据的响应式渲 ...

  3. odoo xml 时间搜索条件

    今年 <filter string="This Year" name="year" domain="[('date','<=', time ...

  4. 转:fork()子进程创建

    源地址:http://blog.chinaunix.net/uid-23037385-id-2565472.html fork()子进程创建 在 UNIX 系统中,用户创建一个新进程的唯一方法就是调用 ...

  5. python 可迭代对象,迭代器,生成器的区别及使用

    可迭代对象 可迭代对象类型:list,dict,tuple,str,set,deque等 如何判断一个对象是否是可迭代对象,可以通过dir()方法看它里面有没有__iter__方法,如果有这个方法就是 ...

  6. docker tomcat启动慢

    镜像 https://hub.docker.com/r/errorlife/tomcat/ docker pull errorlife/tomcat

  7. python-pygame安装教程

    网上有很多关于python,pygame的安装教程.大都比较麻烦,下面为大家介绍一种非常简单的安装方法.(因为安装大都是新手教程写详细一些) python是32位 python是3.6 1 pip配置 ...

  8. CSP-S 2019 Day 2 T3 树的重心

    CSP-S 2019 Day 2 T3 树的重心 题 给出了一个大小为\(n\)的树,树中结点从 1∼n 编号.小简单的课后作业是求出这棵树单独删去每条边后,分裂出的两个子树的重心编号和之和. \(n ...

  9. phpSpider 单页测试_模拟登陆

    <?php require './vendor/autoload.php'; use phpspider\core\phpspider; use phpspider\core\requests; ...

  10. PHP学习1.5-预定义超全局数组变量

    1.PHP 预定义的超全局变量数组 特性: a.特殊的数组,操作方式没有区别 b.不用声明,php脚本中默认存在,因为在php中不用定义,所以在自定义变量是应避免和预定的全局变量同名 c.在全局范围内 ...