标签:原来 树的重心 strong 邻接表 个性 记录 大小 分支 void
概念
void dfs(int u,int fa)
{
vis[u]=1;
//邻接表枚举i的每个相邻节点
for(int i=link[u]; i; i=e[i].next)
{
int v = e[i].u;
if(v!=fa)
dfs(v,u);
}
}
求树的深度
int pos;//记录重心的编号
void dfs(int x,int fa)
{
v[x]=1;
sz[x]=1;
int Maxp=0;
//邻接表枚举i的每个相邻节点
for(int i=link[x]; i; i=e[i].next)
{
int y=e[i].y;
if(y!=fa)
{
dfs(y,x);
sz[x]+=sz[y];
Maxp=max(Maxp,sz[y]);
}
}
Maxp=max(Maxp,n-sz[x]);
if(Maxp<ans)
{
ans=Maxp;
pos=x;
}
}
树的DFS序就是在对树进行DFS的时候,对树的节点进行重新编号;
DFS序有一个很强的性质: 一颗子树的所有节点在DFS序内是连续的一段, 利用这个性质我们可以解决很多问题。
void DFS(int u, int fa)
{
L[u] = ++dfs_clock;
for(int k = head[u]; ~k; k = E[k].next)
{
int v = E[k].to;
if(v == fa) continue;
DFS(v, u);
}
R[u] = dfs_clock;
}
标签:原来 树的重心 strong 邻接表 个性 记录 大小 分支 void
原文地址:https://www.cnblogs.com/Roni-i/p/9112907.html