bzoj2157 旅游——LCT
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2157
仍然是LCT模板题~
不过有一些需要注意的地方,点和边的区分,0号点的 mx 和 mn 等等;
还有变成相反数的处理,要像线段树一样先修改再下传标记,那么查询时候就不用先 pushdown 了;
不过1A还是极好的~
代码如下:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int const maxn=,inf=;
int n,m,fa[maxn],mx[maxn],mn[maxn],sum[maxn],w[maxn],c[maxn][],rev[maxn],tag[maxn],sta[maxn],top;
bool isroot(int x){return c[fa[x]][]!=x && c[fa[x]][]!=x;}
void pushup(int x)
{
int ls=c[x][],rs=c[x][];
sum[x]=sum[ls]+sum[rs]+w[x];
mx[x]=max(mx[ls],mx[rs]); mn[x]=min(mn[ls],mn[rs]);
if(x<=n)return;
mx[x]=max(mx[x],w[x]); mn[x]=min(mn[x],w[x]);
}
void tg(int x)
{
tag[x]^=;
w[x]=-w[x]; sum[x]=-sum[x];
swap(mx[x],mn[x]); mx[x]=-mx[x]; mn[x]=-mn[x];
}
void pushdown(int x)
{
int ls=c[x][],rs=c[x][];
if(rev[x])
{
rev[ls]^=; rev[rs]^=; rev[x]=;
swap(c[x][],c[x][]);
}
if(tag[x])
{
tag[x]=;
if(ls)tg(ls); if(rs)tg(rs);//
}
}
void rotate(int x)
{
int y=fa[x],z=fa[y],d=(c[y][]==x);
if(!isroot(y))c[z][c[z][]==y]=x;
fa[x]=z; fa[y]=x; fa[c[x][!d]]=y;
c[y][d]=c[x][!d]; c[x][!d]=y;
pushup(y); pushup(x);
}
void splay(int x)
{
sta[top=]=x;
for(int i=x;!isroot(i);i=fa[i])sta[++top]=fa[i];
for(;top;top--)pushdown(sta[top]);
for(;!isroot(x);rotate(x))
{
int y=fa[x],z=fa[y];
if(isroot(y))continue;
((c[y][]==x)^(c[z][]==y))?rotate(x):rotate(y);
}
}
void access(int x)
{
for(int t=;x;c[x][]=t,pushup(x),t=x,x=fa[x])splay(x);
}
void makeroot(int x)
{
access(x); splay(x); rev[x]^=;
}
void link(int x,int y)
{
makeroot(x); fa[x]=y;
}
void query(int x,int y)
{
makeroot(x); access(y); splay(y);
}
void change(int x,int t)
{
makeroot(x); w[x]=t; pushup(x);
}
int main()
{
scanf("%d",&n);
mx[]=-inf; mn[]=inf;//
for(int i=,x,y,z;i<n;i++)
{
scanf("%d%d%d",&x,&y,&z); x++; y++;
w[i+n]=z;
link(x,i+n); link(y,i+n);
}
scanf("%d",&m); char ch[];
for(int i=,x,y;i<=m;i++)
{
scanf("%s%d%d",&ch,&x,&y);
if(ch[]=='C')change(x+n,y);
else
{
x++; y++; query(x,y);
if(ch[]=='N')tg(y);
if(ch[]=='S')printf("%d\n",sum[y]);
if(ch[]=='A')printf("%d\n",mx[y]);
if(ch[]=='I')printf("%d\n",mn[y]);
}
}
return ;
}
bzoj2157 旅游——LCT的更多相关文章
- [bzoj2157]旅游 (lct)
		这个应该也算裸的模板题吧..主要是边权的问题,对于每条边u->v,我们可以新建一个节点代替他,把边的信息弄到新的点上,就变成u->x->v了... 当然了这样的话要防止u和v这些没用 ... 
- bzoj2157旅游
		bzoj2157旅游 题意: 给定有权树,支持单边权修改,路径边权取相反数,路径边权求和,路径边权求最大最小值. 题解: 用link-cut tree link-cut tree与树链剖分有些类似,都 ... 
- 【BZOJ2157】旅游 LCT
		模板T,SB的DMoon..其实样例也是中国好样例...一开始不会复制,yangyang:找到“sample input”按住shift,按page down.... #include <ios ... 
- BZOJ2157 旅游  【树剖 或 LCT】
		题目 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间有且只有一条路径. ... 
- [BZOJ2157]旅游(树链剖分/LCT)
		树剖裸题,当然LCT也可以. 树剖: #include<cstdio> #include<algorithm> #define ls (x<<1) #define ... 
- BZOJ2157: 旅游(LCT)
		Description Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间 ... 
- bzoj 2157: 旅游 (LCT 边权)
		链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2157 题面; 2157: 旅游 Time Limit: 10 Sec Memory Lim ... 
- BZOJ2157: 旅游
		传送门 先讲一个悲伤地故事 RunID User Problem Result Memory Time Language Code_Length Submit_Time 1635823 Cydiate ... 
- BZOJ2157旅游——树链剖分+线段树
		题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间有且只有一条路 ... 
随机推荐
- c++基础_01字串
			#include <iostream> using namespace std; int main(){ for(int a=0;a<=1;a++){ for(int b=0;b&l ... 
- Python之面向对象slots与迭代器协议
			Python之面向对象slots与迭代器协议 slots: # class People: # x=1 # def __init__(self,name): # self.name=name # de ... 
- HDU 2815 扩展baby step giant step 算法
			题目大意就是求 a^x = b(mod c) 中的x 用一般的baby step giant step 算法会超时 这里参考的是http://hi.baidu.com/aekdycoin/item/2 ... 
- bzoj3295 [Cqoi2011]动态逆序对 cdq+树状数组
			[bzoj3295][Cqoi2011]动态逆序对 2014年6月17日4,7954 Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数. ... 
- 转载:C/C++检测内存泄漏的工具 vld Visual Leak Detector223 的使用方法和sample示例
			这类的工具有 比如 :LeakDiag leakfinder "Visual Leak Detector" vld可以从http://vld.codeplex.com/releas ... 
- POJ 1064_Cable master
			题意: 给定一系列长度的电缆,将他们切成K条相等长度的电缆,问每条最长有多长? 分析: 对长度进行二分,判断能否满足K条. 二分搜索: 在求解最大化或最小化问题中,能够比较简单的判断条件是否满足,那么 ... 
- Webstrom打开太慢
			让webstrom将安装包目录屏蔽,settings-搜索file types-在ignore file and folders加入node_modules目录,操作方式如下: 
- 008 frame relay
			Router>en Router#config t Enter configuration commands, one per line. End with CNTL/Z. Router(co ... 
- vsftpd.conf案例
			1. 匿名服务器的连接(独立的服务器) 在/etc/vsftpd/vsftpd.conf配置文件中添加如下几项:Anonymous_enable=yes (允许匿名登陆)Dirmessage_enab ... 
- day4-hdfs的核心工作原理\写数据流程 \读数据流程
			namenode元数据管理要点 1.什么是元数据? hdfs的目录结构及每一个文件的块信息(块的id,块的副本数量,块的存放位置<datanode>) 2.元数据由谁负责管理? namen ... 
