CF1137F Matches Are Not a Child's Play(LCT思维题)
题目
CF1137F
很有意思的题目
做法
直接考虑带修改的做法,上一次最大值为u,这次修改v,则最大值为v了
我们发现:\(u-v\)这条链会留到最后,序列里的其他元素相对位置不变,这条链会\(u\longrightarrow v\)排到最后
序列会分成很多块,而这些块是以链为基础的
可以用\(LCT\)来做,具体说一下:
最大值放到根,修改v,就把\(v\)换成根,这个时候会拉一条链\(u-v\),此时\(u\)在\(v\)的右子树,\(x\)在单个块中的排序,就是\(LCT\)里单个\(splay\)比\(x\)大的数量\(+1\)
在\(splay\)外的个数,就是其他块的总和,每条链用一个时间轴\(tim\)记录,在换根的时候就会变化经过的每条链的大小
考虑带修前缀和,用树状数组维护
Code
#include<bits/stdc++.h>
typedef int LL;
const LL maxn=1e6+9;
void Dfs(LL u,LL f);
inline LL Read(){
LL x(0),f(1); char c=getchar();
while(c<'0' || c>'9'){
if(c=='-') f=-1; c=getchar();
}
while(c>='0' && c<='9'){
x=(x<<3)+(x<<1)+c-'0'; c=getchar();
}
return x*f;
}
struct node{
LL to,nxt;
}dis[maxn];
LL num,tim;
LL head[maxn];
inline void Add(LL u,LL v){
dis[++num]=(node){v,head[u]}; head[u]=num;
}
struct BIT{
LL up;
LL tree[maxn];
inline LL Lowbit(LL x){
return x&-x;
}
inline void Add(LL x,LL val){
for(x;x<=up;x+=Lowbit(x)) tree[x]+=val;
}
inline LL Query(LL x){
LL ret(0);
for(;x;x-=Lowbit(x)) ret+=tree[x];
return ret;
}
}t1;
struct LCT{
LL fa[maxn],son[maxn][2],size[maxn],lazy[maxn],r[maxn],col[maxn],sta[maxn];
inline LL N_rt(LL x){
return son[fa[x]][0]==x||son[fa[x]][1]==x;
}
inline void Up(LL x){
size[x]=size[son[x][0]]+size[son[x][1]]+1;
}
inline void Ro(LL x){
LL y(fa[x]),z(fa[y]),lz(son[y][1]==x);
if(N_rt(y)){
son[z][son[z][1]==y]=x;
}fa[x]=z;
son[y][lz]=son[x][lz^1]; if(son[y][lz]) fa[son[y][lz]]=y;
son[x][lz^1]=y; fa[y]=x;
Up(y); Up(x);
}
inline void Pr(LL x){
std::swap(son[x][0],son[x][1]); r[x]^=1;
}
inline void Pd(LL x){
LL lc(son[x][0]),rc(son[x][1]);
if(r[x]){
if(lc) Pr(lc);
if(rc) Pr(rc);
r[x]=0;
}
if(lazy[x]){
if(lc) col[lc]=lazy[lc]=lazy[x];
if(rc) col[rc]=lazy[rc]=lazy[x];
lazy[x]=0;
}
}
inline void Splay(LL x){
LL top(0),y(x); sta[++top]=y;
while(N_rt(y)) y=fa[y],sta[++top]=y;
while(top) Pd(sta[top--]);
while(N_rt(x)){
y=fa[x];
if(N_rt(y)){
LL z(fa[y]);
if((son[y][1]==x)^(son[z][1]==y)) Ro(x);else Ro(y);
}Ro(x);
}
}
inline void Ac(LL x,LL id){
LL y(0);
for(;x;y=x,x=fa[x]){
Splay(x); LL z(son[x][1]);
t1.Add(col[x],size[z]-size[x]);
son[x][1]=y;
Up(x);
}
t1.Add(id,size[y]); lazy[y]=id; col[y]=id;
}
inline void Mk_rt(LL x,LL id){
Ac(x,id); Splay(x); Pr(x);
}
inline LL Query(LL u){
Splay(u); LL ret(t1.Query(col[u]-1));
ret+=size[son[u][1]]+1;
return ret;
}
}t2;
LL n,m;
char s[maxn];
int main(){
n=Read(); m=Read();
for(LL i=1;i<n;++i){
LL u(Read()),v(Read());
Add(u,v); Add(v,u);
}
Dfs(1,0);
t1.up=(n<<1)+m;
for(LL i=1;i<=n;++i){
t2.col[i]=i; t2.size[i]=1;
t1.Add(i,1);
}
tim=n;
for(LL i=1;i<=n;++i)
t2.Mk_rt(i,++tim);
while(m--){
scanf(" %s",s+1); LL u,v;
if(s[1]=='u'){
u=Read();
t2.Mk_rt(u,++tim);
}else if(s[1]=='w'){
u=Read();
printf("%d\n",t2.Query(u));
}else{
u=Read(); v=Read();
printf("%d\n",t2.Query(u)<t2.Query(v)?u:v);
}
}
}
void Dfs(LL u,LL f){
for(LL i=head[u];i;i=dis[i].nxt){
LL v(dis[i].to); if(v==f) continue;
Dfs(v,u);
t2.fa[v]=u;
}
}
CF1137F Matches Are Not a Child's Play(LCT思维题)的更多相关文章
- [Codeforces1137F]Matches Are Not a Child's Play——LCT+树状数组
题目链接: [Codeforces1137F]Matches Are Not a Child's Play 题目大意: 我们定义一棵树的删除序列为:每一次将树中编号最小的叶子删掉,将该节点编号加入到当 ...
- CF1137F Matches Are Not a Child's Play(树链剖分)
题面 我们定义一棵树的删除序列为:每一次将树中编号最小的叶子删掉,将该节点编号加入到当前序列的最末端,最后只剩下一个节点时将该节点的编号加入到结尾. 例如对于上图中的树,它的删除序列为:2 4 3 1 ...
- 【树链剖分 ODT】cf1137F. Matches Are Not a Child's Play
孔爷的杂题系列:LCT清新题/ODT模板题 题目大意 定义一颗无根树的燃烧序列为:每次选取编号最小的叶子节点形成的序列. 要求支持操作:查询一个点$u$在燃烧序列中的排名:将一个点的编号变成最大 $n ...
- CF1137F Matches Are Not a Child's Play
我们定义一棵树的删除序列为:每一次将树中编号最小的叶子删掉,将该节点编号加入到当前序列的最末端,最后只剩下一个节点时将该节点的编号加入到结尾.现在给出一棵n个节点的树,有m次操作: up v:将v号节 ...
- [cf1137F]Matches Are Not a Child's Pla
显然compare操作可以通过两次when操作实现,以下仅考虑前两种操作 为了方便,将优先级最高的节点作为根,显然根最后才会被删除 接下来,不断找到剩下的节点中(包括根)优先级最高的节点,将其到其所在 ...
- Codeforces 1137F Matches Are Not a Child's Play [LCT]
Codeforces 很好,通过这题对LCT的理解又深了一层. 思路 (有人说这是套路题,然而我没有见过/kk) 首先发现,删点可以从根那里往下删,非常难受,所以把权值最大的点提为根. 然后考虑\(x ...
- Codeforces 1137F - Matches Are Not a Child's Play(LCT)
Codeforces 题面传送门 & 洛谷题面传送门 考虑将一个点 \(x\) 的编号变为当前所有点编号最大值 \(+1\) 会对每个点的删除时间产生怎么样的影响.由于编号最大的点肯定是最后一 ...
- LCT[Link-Cut-Tree学习笔记]
部分摘抄于 FlashHu candy99 所以文章篇幅较长 请有足够的耐心(不是 其实不用学好splay再学LCT的-/kk (至少现在我平衡树靠fhq) 如果学splay的话- 也许我菜吧-LCT ...
- 多校联训 DS 专题
CF1039D You Are Given a Tree 容易发现,当 \(k\) 不断增大时,答案不断减小,且 \(k\) 的答案不超过 \(\lfloor\frac {n}{k}\rfloor\) ...
随机推荐
- [Go语言]从Docker源码学习Go——Interfaces
Interface定义: type Namer interface { Method1(param_list) return_type Method2(param_list) return_type ...
- iermu爱耳目
百度推出720P 云直播摄像头 查看直播请点击 直播 互联网网盘新动向实现初见端倪,之前写过一篇关于互联网网盘的思考. 我只是仅仅有想法而已,百度已经实现了一部分. 具体功能参见http://www. ...
- Navicat连接阿里云(centos7.3)的MySQL数据库遇到的问题及解决方法
注:本文涉及到的解决方案都是我遇到的问题的对应解决方案,不一定适用于每一个人,如果问题仍然存在,请继续百度查询其他解决方法 1. 首先是登录阿里云MySQL的一些必要信息(登录其他云主机的mysql ...
- JDK的图文安装教程
JDK的安装 什么是JDK? JDK就是Java开发工具包,即Java Development Kit.就是做Java开发所需要的最基本的工具.包括Java编译器(把人使用的Java语言变成JVM能运 ...
- ubuntu下安装myeclipse+破解
1.给myeclipseInstaller.run权限 chmod myeclipseInstaller.run 2.安装(结束时不启动,去掉√) ./myeclipseInstaller.run 3 ...
- Servlet------>jsp输出JavaBean
JavaBean是遵循特殊写法的java类 它通常具有如下特点: 1.这个java类必须具有一个无参的构造函数 2.属性必须私有化 3.私有化必须通过public类暴露给其他程序,而且方法的命名必须遵 ...
- CSS语义化命名
CSS语义化命名 从上图我们可以大概看出这里有两种CSS的命名方式:1.结构化命名法:2.语义化命名法. 结构化命名法:根据页面中板块的位置而命名,如上图中的content-left,这时如果我们想把 ...
- HTTP代理服务器基本知识
http://www.cnblogs.com/TankXiao/archive/2012/12/12/2794160.html https://blog.csdn.net/xiaoxiaorenky/ ...
- 20.Bulk Write Operations-官方文档摘录
1.有序操作列表将会串行执行,但如果在一个写操作过程出现异常错误,则不会处理剩余的任何写操作 2.无序操作列表将会并发执行,如果在一个写操作过程出现异常错误,则不影响,继续执行(并发无序) 3.对比无 ...
- Loki之Funtion
阅读Loki中Funtion源码之后的个人理解,该库归纳起来可以说有三层(C++设计新思维列举到2个参数,此处列举到3个参数),要记住C++的模板其实就是C语言高级的宏定义,如果用户没有用到对应的模板 ...