BZOJ3083: 遥远的国度
BZOJ100题辣(已经无法直视的正确率
树剖板子题,注意和dfs序结合,根据根的变化变换统计的方式即可。
//BZOJ 3083
//by Cydiater
//2016.10.23
#include <iostream>
#include <cstring>
#include <string>
#include <algorithm>
#include <queue>
#include <map>
#include <ctime>
#include <iomanip>
#include <cstdlib>
#include <cstdio>
#include <cmath>
using namespace std;
#define ll long long
#define up(i,j,n) for( int i=j;i<=n;i++)
#define down(i,j,n) for(int i=j;i>=n;i--)
#define FILE "bbbbb"
const int MAXN=1e5+5;
const ll oo=1LL<<32;
inline ll read(){
char ch=getchar();ll x=0,f=1;
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
int N,M,dep[MAXN],LINK[MAXN],len=0,fa[MAXN][25],son[MAXN],siz[MAXN],top[MAXN],seg[MAXN],cnt=0,pos[MAXN],ROOT,opt,L,R;
ll v,pro[MAXN];
int c=0;
struct edge{
int y,next;
}e[MAXN<<1];
struct Tree{
ll v,delta;
}t[MAXN<<3];
namespace solution{
inline void insert(int x,int y){e[++len].next=LINK[x];LINK[x]=len;e[len].y=y;}
inline void reload(int root){t[root].v=min(t[root<<1].v,t[root<<1|1].v);}
inline void downit(int root){
if(t[root].delta==0)return;
int delta=t[root].delta;t[root].delta=0;
t[root<<1].delta=delta;t[root<<1].v=delta;
t[root<<1|1].delta=delta;t[root<<1|1].v=delta;
}
void init(){
N=read();M=read();
up(i,2,N){
int x=read(),y=read();
insert(x,y);
insert(y,x);
}
up(i,1,N)pro[i]=read();
ROOT=read();
}
void dfs1(int node,int deep,int father){
fa[node][0]=father;dep[node]=deep;son[node]=0;
siz[node]=1;int max_siz=0;
for(int i=LINK[node];i;i=e[i].next)if(e[i].y!=father){
dfs1(e[i].y,deep+1,node);
siz[node]+=siz[e[i].y];
if(siz[e[i].y]>max_siz){
max_siz=siz[e[i].y];
son[node]=e[i].y;
}
}
}
void dfs2(int node,int TOP){
top[node]=TOP;seg[++cnt]=node;pos[node]=cnt;
if(son[node])dfs2(son[node],TOP);
for(int i=LINK[node];i;i=e[i].next)if(e[i].y!=fa[node][0]&&e[i].y!=son[node])
dfs2(e[i].y,e[i].y);
}
void get_ancestor(){
up(i,1,21)up(node,1,N)if(fa[node][i-1]!=0)
fa[node][i]=fa[fa[node][i-1]][i-1];
}
void build(int leftt,int rightt,int root){
if(leftt==rightt){
t[root].delta=0;
t[root].v=pro[seg[leftt]];
return;
}
int mid=(leftt+rightt)>>1;
build(leftt,mid,root<<1);
build(mid+1,rightt,root<<1|1);
reload(root);
}
void Build(){
dfs1(ROOT,0,0);dfs2(ROOT,ROOT);
get_ancestor();
build(1,N,1);
}
int LCA(int x,int y){
if(x==y) return x;
if(dep[x]<dep[y])swap(x,y);
down(i,21,0)if(dep[x]-(1<<i)>=dep[y])x=fa[x][i];
if(x==y) return x;
down(i,21,0)if(fa[x][i]!=0&&fa[x][i]!=fa[y][i]){
x=fa[x][i];
y=fa[y][i];
}
return fa[x][0];
}
void updata(int leftt,int rightt,int root){
downit(root);
if(leftt>R||rightt<L) return;
if(leftt>=L&&rightt<=R){
t[root].delta=t[root].v=v;
return;
}
int mid=(leftt+rightt)>>1;
updata(leftt,mid,root<<1);
updata(mid+1,rightt,root<<1|1);
reload(root);
}
void change(int x,int aim){
while(top[x]!=top[aim]){
R=pos[x];L=pos[top[x]];
updata(1,N,1);
x=fa[top[x]][0];
}
R=pos[x];L=pos[aim];
updata(1,N,1);
}
void Change(int x,int y){
int lca=LCA(x,y);
change(x,lca);change(y,lca);
}
ll get(int leftt,int rightt,int root){
downit(root);
if(leftt>R||rightt<L) return oo;
if(leftt>=L&&rightt<=R) return t[root].v;
int mid=(leftt+rightt)>>1;
return min(get(leftt,mid,root<<1),get(mid+1,rightt,root<<1|1));
}
void slove(){
while(M--){
opt=read();
if(opt==1)ROOT=read();
else if(opt==2){
int x=read(),y=read();v=read();
Change(x,y);
}else{
int node=read(),Pos=pos[ROOT];ll ans;
int leftt=pos[node],rightt=leftt+siz[node]-1;
if(Pos==leftt){
L=1;R=N;
ans=get(1,N,1);
}else if(!(Pos>=leftt&&Pos<=rightt)){
L=leftt;R=rightt;
ans=get(1,N,1);
}else{
for(int i=LINK[node];i;i=e[i].next)if(e[i].y!=fa[node][0]){
leftt=pos[e[i].y];rightt=pos[e[i].y]+siz[e[i].y]-1;
if(Pos>=leftt&&Pos<=rightt){
L=1;R=leftt-1;
if(R>=L)ans=get(1,N,1);
L=rightt+1,R=N;
if(L<=R)ans=min(ans,get(1,N,1));
break;
}
}
}
printf("%lld\n",ans);
}
}
}
}
int main(){
//freopen(FILE".in","r",stdin);
//freopen(FILE".out","w",stdout);
//freopen("input.in","r",stdin);
//freopen("out.out","w",stdout);
using namespace solution;
init();
Build();
slove();
return 0;
}
BZOJ3083: 遥远的国度的更多相关文章
- BZOJ3083 遥远的国度 【树链剖分】
BZOJ3083 遥远的国度 Description zcwwzdjn在追杀十分sb的zhx,而zhx逃入了一个遥远的国度.当zcwwzdjn准备进入遥远的国度继续追杀时,守护神RapiD阻拦了zcw ...
- bzoj3083 遥远的国度 && bzoj3626 LCA (树链剖分)
今早刷了两道树剖的题目,用时两小时十五分钟= = 树剖的题目代码量普遍120+ 其实打熟练之后是很容易调的,不熟练的话代码量大可能会因为某些小细节调很久 3083:裸树剖+"换根" ...
- [luogu3979][bzoj3083]遥远的国度
[luogu传送门] [bzoj传送门] 题目描述 zcwwzdjn在追杀十分sb的zhx,而zhx逃入了一个遥远的国度.当zcwwzdjn准备进入遥远的国度继续追杀时,守护神RapiD阻拦了zcww ...
- 2018.06.30 BZOJ3083: 遥远的国度(换根树剖)
3083: 遥远的国度 Time Limit: 10 Sec Memory Limit: 512 MB Description 描述 zcwwzdjn在追杀十分sb的zhx,而zhx逃入了一个遥远的国 ...
- BZOJ3083 遥远的国度(树链剖分+线段树)
考虑暴力树剖.那么修改路径和查询子树最小值非常简单. 对于换根当然不能真的给他转一下,我们只记录当前根是哪个.对于查询,如果查询点不在当前根到原根的路径上,显然换根是对答案没有影响的:如果是当前根,答 ...
- 【树链剖分】【线段树】bzoj3083 遥远的国度
记最开始的根为root,换根之后,对于当前的根rtnow和询问子树U而言, ①rtnow==U,询问整棵树 ②fa[rtnow]==U,询问除了rtnow所在子树以外的整棵树 ③rtnow在U的子树里 ...
- BZOJ3083 遥远的国度 【树剖】
题目 zcwwzdjn在追杀十分sb的zhx,而zhx逃入了一个遥远的国度.当zcwwzdjn准备进入遥远的国度继续追杀时,守护神RapiD阻拦了zcwwzdjn的去路,他需要zcwwzdjn完成任务 ...
- BZOJ3083——遥远的国度
1.题目大意:三个操作,换根,修改树上的某条路径,查询一个子树的最小值 2.分析:这个其实还是挺好做的,修改树上的某条路径,裸树剖,查询子树的最小值,这个是树剖满足dfs序 那么就是换根了,对吧,其实 ...
- bzoj3083 遥远的国度 题解
题目大意: 给定一棵有根树,每个点有一个权值,提供三种操作: 1.将x节点变为根节点 2.将x到y路径上的点的权值全部改为v 3.询问x的子树中点权的最小值 思路: 用DFS序剖分,记录每个节点入栈出 ...
随机推荐
- SQL Server删除distribution数据库二
以前总结过一遍博文SQL Server删除distribution数据库,里面介绍了如何删除distribution数据库.今天介绍一个删除distribution的特殊案例, 在这之前,我不知道这个 ...
- WPF 显示文件列表中使用 ListBox 变到ListView 最后使用DataGrid
WPF 显示文件列表中使用 ListBox 变到ListView 最后使用DataGrid 故事背景: 需要检索某目录下文件,并列出来,提供选择和其他功能. 第一版需求: 列出文件供选择即可,代码如下 ...
- JVM之方法区
基本特性: 线程共享区域,存储被JVM加载的类信息.常量.静态变量.即时编译器编译的代码等 堆的逻辑部分,不限定方法去内的内存位置和编译代码的管理策略,不限定实现垃圾回收 容量可不定也可动态扩展,不 ...
- 再探banana
在Solr图形化界面:除Hue之外的选择中列出了banana的如下一些不足,今天再次研究这些地方是否有方案可以解决. 1.sunburst图功能没法用. 2.中文有些地方会显示%2B%4C之类的一串字 ...
- 使用JNI封装底层input系统提供的event事件
首先说下思路,本文采用jni技术封装底层触摸事件,封装成MotionEvent类一样,不过没有android系统MotionEvent强大.源码MotionEvent位置:java-->fram ...
- Centos7中所有的关机命令的奇怪现象
今天在研究shutdown,reboot,halt,poweroff几种关机命令的区别是发现他们都是/bin/systemctl的软连接 ls -l /sbin/{shutdown,reboot,ha ...
- Apache配置
redhat6.4企业版用的centos的yum源. 下面进行apache的安装与配置. 1.yum在线安装Apache 一般不采用yum在线安装因为如果apache坏掉了,yum安装过程中会有依赖的 ...
- 添加文件到HDFS的集中缓存
需求是这样的,有一些文件,需要常驻内存,提高读取效率的情况下,可以使用HDFS的缓存机制进行预先缓存 先添加POOL,然后添加需要缓存的文件即可 hdfs cacheadmin -.tar.gz - ...
- 【读书笔记《Bootstrap 实战》】3.优化站点资源、完成响应式图片、让传送带支持手势
A.优化站点资源 速度很重要.用户很关心.我们的站点必须加载够快,否则用户就会走人.SEO 也很重要.我们的站点必须加载够快,否者搜索排名就会下降. 明白了这样,我们就来清点一下 [Bootstrap ...
- pyqt5-为QListWidget添加右键菜单
如何在pyqt5下为QListWidget添加右键菜单? 能百度到的均是pyqt4下的,有些貌似并不好用. 在尝试了很多方法后,下面贴出可用的方法: from PyQt4 import QtCore, ...