Description:

给定一棵树,每次询问u节点在以v为根时的子树权值最大值

Hint:

\(n \le 10^5\)

Solution:

这个模型还是很重要的

考虑树剖

以1节点为根建树

当\(v\)在\(u\)外时,显然直接搞

否则就把\(v\)跳到它的\(dep[v]-dep[u]-1\)级父亲,看是\(u\)的哪棵子树,除去这棵子树的就是答案区间

写个倍增就好了

#include <map>
#include <set>
#include <stack>
#include <cmath>
#include <queue>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#define ls p<<1
#define rs p<<1|1
using namespace std;
typedef long long ll;
const int mxn=1e6+5,inf=2147483647;
int n,m,tot,cnt,cap;
int a[mxn],f[mxn][22],hd[mxn],sz[mxn],rk[mxn],top[mxn],dfn[mxn],dep[mxn],son[mxn];
int tr[mxn<<2],tag[mxn<<2]; inline int read() {
char c=getchar(); int x=0,f=1;
while(c>'9'||c<'0') {if(c=='-') f=-1;c=getchar();}
while(c<='9'&&c>='0') {x=(x<<3)+(x<<1)+(c&15);c=getchar();}
return x*f;
} inline void chkmax(int &x,int y) {if(x<y) x=y;}
inline void chkmin(int &x,int y) {if(x>y) x=y;} struct ed {
int to,nxt;
}t[mxn<<1]; inline void add(int u,int v) {
t[++cnt]=(ed) {v,hd[u]}; hd[u]=cnt;
} int up(int x,int h)
{
for(int i=21;i>=0;--i)
if(h&(1<<i)) x=f[x][i];
return x;
} void push_up(int p) {
tr[p]=inf;
chkmin(tr[p],min(tr[ls],tr[rs]));
} void push_down(int p) {
if(tag[p]) {
tag[ls]=tag[rs]=tag[p];
tr[ls]=tr[rs]=tag[p];
tag[p]=0;
}
} void dfs(int u,int fa) {
f[u][0]=fa; sz[u]=1; dep[u]=dep[fa]+1;
for(int i=hd[u];i;i=t[i].nxt) {
int v=t[i].to;
if(v==fa) continue ;
dfs(v,u); sz[u]+=sz[v];
if(sz[son[u]]<sz[v]) son[u]=v;
}
} void dfs1(int u,int tp) {
top[u]=tp; dfn[u]=++tot; rk[tot]=u;
if(son[u]) dfs1(son[u],tp);
for(int i=hd[u];i;i=t[i].nxt) {
int v=t[i].to;
if(v==f[u][0]||v==son[u]) continue ;
dfs1(v,v);
}
} void update(int l,int r,int ql,int qr,int val,int p)
{
if(ql<=l&&r<=qr) {
tr[p]=val;
tag[p]=val;
return ;
}
int mid=(l+r)>>1; push_down(p);
if(ql<=mid) update(l,mid,ql,qr,val,ls);
if(qr>mid) update(mid+1,r,ql,qr,val,rs);
push_up(p);
} int LCA(int x,int y) {
if(dep[x]<dep[y]) swap(x,y);
for(int i=21;i>=0;--i)
if(dep[f[x][i]]>=dep[y])
x=f[x][i];
if(x==y) return x;
for(int i=21;i>=0;--i)
if(f[x][i]!=f[y][i])
x=f[x][i],y=f[y][i];
return f[x][0];
} void modify(int x,int y,int w)
{
while(top[x]!=top[y]) {
if(dep[top[x]]<dep[top[y]]) swap(x,y);
update(1,n,dfn[top[x]],dfn[x],w,1);
x=f[top[x]][0];
}
if(dep[x]>dep[y]) swap(x,y);
update(1,n,dfn[x],dfn[y],w,1);
} int query(int l,int r,int ql,int qr,int p)
{
if(ql<=l&&r<=qr) return tr[p];
int mid=(l+r)>>1; push_down(p); int res=inf;
if(ql<=mid) chkmin(res,query(l,mid,ql,qr,ls));
if(qr>mid) chkmin(res,query(mid+1,r,ql,qr,rs));
return res;
} int solve(int x)
{
if(x==cap) return query(1,n,1,n,1); //切记要特判,不然会错
if(dfn[cap]>dfn[x]&&dfn[cap]<dfn[x]+sz[x]) {
int pos=up(cap,dep[cap]-dep[x]-1);
return min(query(1,n,1,dfn[pos]-1,1),query(1,n,dfn[pos]+sz[pos],n,1));
}
else return query(1,n,dfn[x],dfn[x]+sz[x]-1,1);
} void build(int l,int r,int p)
{
if(l==r) {
tr[p]=a[rk[l]];
return ;
}
int mid=(l+r)>>1;
build(l,mid,ls);
build(mid+1,r,rs);
push_up(p);
} int main()
{
int u,v,x,y,w,opt;
n=read(); m=read();
for(int i=1;i<n;++i) {
u=read(); v=read();
add(u,v); add(v,u);
}
for(int i=1;i<=n;++i) a[i]=read();
dfs(1,0); dfs1(1,1); build(1,n,1);
for(int j=1;j<=21;++j)
for(int i=1;i<=n;++i)
f[i][j]=f[f[i][j-1]][j-1]; cap=read();
for(int i=1;i<=m;++i) {
opt=read();
if(opt==1) {
x=read();
cap=x;
}
else if (opt==2) {
x=read(),y=read(); w=read();
modify(x,y,w);
}
else {
x=read();
printf("%d\n",solve(x));
}
}
return 0;
}

[BZOJ3038]遥远的国度的更多相关文章

  1. BZOJ 3083: 遥远的国度 [树链剖分 DFS序 LCA]

    3083: 遥远的国度 Time Limit: 10 Sec  Memory Limit: 1280 MBSubmit: 3127  Solved: 795[Submit][Status][Discu ...

  2. BZOJ 3083: 遥远的国度 dfs序,树链剖分,倍增

    今天再做一天树的题目,明天要开始专攻图论了.做图论十几天之后再把字符串搞搞,区域赛前再把计几看看. 3083: 遥远的国度 Time Limit: 10 Sec  Memory Limit: 128 ...

  3. BZOJ 3083 遥远的国度 树链剖分

    3083: 遥远的国度 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 797  Solved: 181[Submit][Status] Descrip ...

  4. BZOJ_3083_遥远的国度_树链剖分+线段树

    BZOJ_3083_遥远的国度_树链剖分 Description 描述 zcwwzdjn在追杀十分sb的zhx,而zhx逃入了一个遥远的国度.当zcwwzdjn准备进入遥远的国度继续追杀时,守护神Ra ...

  5. [luogu3979][bzoj3083]遥远的国度

    [luogu传送门] [bzoj传送门] 题目描述 zcwwzdjn在追杀十分sb的zhx,而zhx逃入了一个遥远的国度.当zcwwzdjn准备进入遥远的国度继续追杀时,守护神RapiD阻拦了zcww ...

  6. P3979 遥远的国度

    P3979 遥远的国度 思路 一开始我用这个函数得到左端点 int get_l(int x,int y) { if(top[x]==top[y]) return son[x]; int last=to ...

  7. 2018.06.30 BZOJ3083: 遥远的国度(换根树剖)

    3083: 遥远的国度 Time Limit: 10 Sec Memory Limit: 512 MB Description 描述 zcwwzdjn在追杀十分sb的zhx,而zhx逃入了一个遥远的国 ...

  8. 【BZOJ】【3083】遥远的国度

    树链剖分/dfs序 其实过了[BZOJ][4034][HAOI2015]T2以后就好搞了…… 链修改+子树查询+换根 其实静态树的换根直接树链剖分就可以搞了…… 因为其实只有一样变了:子树 如果roo ...

  9. 【树链剖分换根】P3979 遥远的国度

    Description zcwwzdjn在追杀十分sb的zhx,而zhx逃入了一个遥远的国度.当zcwwzdjn准备进入遥远的国度继续追杀时,守护神RapiD阻拦了zcwwzdjn的去路,他需要zcw ...

随机推荐

  1. C++ Primer 笔记——迭代器

    iostream迭代器 1.虽然iostream类不是容器,但是标准库定义了可以用于IO的迭代器.创建一个流迭代器的时候必须指定要读写的类型.我们可以对任何具有输入运算符(>>)的类型定义 ...

  2. 论文阅读笔记二十七:Faster R-CNN: Towards Real-Time Object Detection with Region Proposal Networks(CVPR 2016)

    论文源址:https://arxiv.org/abs/1506.01497 tensorflow代码:https://github.com/endernewton/tf-faster-rcnn 室友对 ...

  3. C#线性表

    线性表是线性结构的抽象 线性结构的特点是结构中的数据元素之间存在一对一的线性关系 一对一的关系指的是数据元素之间的位置关系 (1)除第一个位置的数据元素外,其它数据元素位置的前面都只有一个数据元素 ( ...

  4. HTTP.sys远程执行代码漏洞

    远程执行代码漏洞存在于 HTTP 协议堆栈 (HTTP.sys) 中,当 HTTP.sys 未正确分析经特殊设计的 HTTP 请求时会导致此漏洞. http://bbs.safedog.cn/thre ...

  5. Codeforces 196E Opening Portals MST (看题解)

    Opening Portals 我们先考虑如果所有点都是特殊点, 那么就是对整个图求个MST. 想在如果不是所有点是特殊点的话, 我们能不能也 转换成求MST的问题呢? 相当于我们把特殊点扣出来, 然 ...

  6. BZOJ3772 精神污染 主席树 dfs序

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3772 题意概括 给出一个树,共n个节点. 有m条互不相同的树上路径. 现在让你随机选择2条路径,问 ...

  7. P1892 [BOI2003]团伙 并查集

    题目描述 1920年的芝加哥,出现了一群强盗.如果两个强盗遇上了,那么他们要么是朋友,要么是敌人.而且有一点是肯定的,就是: 我朋友的朋友是我的朋友: 我敌人的敌人也是我的朋友. 两个强盗是同一团伙的 ...

  8. Idea问题:“marketplace plugins are not loaded”解决方案

    博主本人遇见该问题时是想要通过Idea的plugins工具下载阿里巴巴的代码规约工具 但是在我点开settings,然后打开plugins工具时竟然给我提示“marketplace plugins a ...

  9. CentOS系统找不到setup命令工具的解决方法

    如果你的CentOS系统中没有setup命令,很有可能是因为你安装CentOS系统时采用了最小化安装(minimal).这时,你执行setup命令时,就会报错: 错误信息: 1[root@localh ...

  10. Qt5.11.1安装与VS2017配置

    Qt5.11.1安装与VS2017配置 转 https://blog.csdn.net/gaojixu/article/details/82185694 文章目录 Qt5.11.1安装与VS2017配 ...