ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

树链剖分

2022-04-03 18:04:01  阅读:143  来源: 互联网

标签:tmp 剖分 int tp son dfs2 edge 树链


LCA

struct Edge{
	int v,nxt;
}edge[maxn];
int head[maxn],tot=0;
inline void read(int &x){
	x=0;char tmp=getchar();
	while(tmp<'0'||tmp>'9')tmp=getchar();
	while(tmp>='0'&&tmp<='9')x=(x<<1)+(x<<3)+tmp-'0',tmp=getchar();
}
inline void add_edge(int x,int y){
	edge[tot].v=y,edge[tot].nxt=head[x],head[x]=tot++;
}
int dep[maxn],sz[maxn],son[maxn],fa[maxn];
int top[maxn],id[maxn],dfs_clock=0;
void dfs1(int u,int depth){
	dep[u]=depth,sz[u]=1,son[u]=-1;
	for(int i=head[u];i!=-1;i=edge[i].nxt){
		int v=edge[i].v;
                if(dep[v])continue;
		fa[v]=u;
		dfs1(v,depth+1);
		sz[u]+=sz[v];
		if(son[u]==-1||sz[v]>sz[son[u]])son[u]=v;
	}
}
void dfs2(int u,int tp){
	top[u]=tp,id[u]=++dfs_clock;
	if(son[u]==-1)return;
	dfs2(son[u],tp);
	for(int i=head[u];i!=-1;i=edge[i].nxt){
		int v=edge[i].v;
		if(v!=son[u]&&v!=fa)
			dfs2(v,v);
	}
}
int lca(int x,int y){//也可以swap不过这个常数小点
	if(y>n)return 0;
	while(top[x]!=top[y]){
		if(dep[top[x]]<dep[top[y]])y=fa[top[y]];
		else x=fa[top[x]];
	}
	if(dep[x]<dep[y])return x;
	else return y;
}

链/子树上操作

struct Edge{
	int v,nxt;
}edge[maxn];
int head[maxn],tot=0;
inline void read(int &x){
	x=0;char tmp=getchar();
	while(tmp<'0'||tmp>'9')tmp=getchar();
	while(tmp>='0'&&tmp<='9')x=(x<<1)+(x<<3)+tmp-'0',tmp=getchar();
}
inline void add_edge(int x,int y){
	edge[tot].v=y,edge[tot].nxt=head[x],head[x]=tot++;
}
int dep[maxn],sz[maxn],son[maxn],fa[maxn];
int top[maxn],id[maxn],dfs_clock=0;
void dfs1(int u,int depth){
	dep[u]=depth,sz[u]=1,son[u]=-1;
	for(int i=head[u];i!=-1;i=edge[i].nxt){
		int v=edge[i].v;
                if(dep[v])continue;
		fa[v]=u;
		dfs1(v,depth+1);
		sz[u]+=sz[v];
		if(son[u]==-1||sz[v]>sz[son[u]])son[u]=v;
	}
}
void dfs2(int u,int tp){
	top[u]=tp,id[u]=++dfs_clock;
	if(son[u]==-1)return;
	dfs2(son[u],tp);
	for(int i=head[u];i!=-1;i=edge[i].nxt){
		int v=edge[i].v;
		if(v!=son[u]&&v!=fa)
			dfs2(v,v);
	}
}

标签:tmp,剖分,int,tp,son,dfs2,edge,树链
来源: https://www.cnblogs.com/xyc1719/p/16096741.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有