0x21 树与图的遍历
0x21 树与图的遍历
1.树的深度遍历
void dfs(int x){
vis[x]=1;
for(int i=head[x];i;i=edge[i].next){
int y=edge[i].to;
if(vis[y]) continue;
dfs(y);
}
}
2.时间戳
//dfn[]
//以每个节点第一次访问的顺序,依此打上1~N的标记,称为时间戳
3.树的DFS序
//记录各点dfs访问和回溯顺序的序列
//这个序列中,设两次出现位置为L[x],R[x],那么区间[ L[x] , R[x] ] 就是以x为根的子树的dfs序
//很多树相关问题,可以通过dfs序把子树统计转换为序列上的区间统计
void dfs(int x){
a[++m]=x; //a数组存储dfs序
vis[x]=1;
for(int i=head[x];i;i=edge[i].next){
int y=edge[i].to;
if(vis[y])continue;
dfs(y);
}
a[++m]=x;
}
4.树的深度
void dfs(int x){
vis[x]=1;
for(int i=head[x];i;i=edge[i].next){
int y=edge[i].to;
if(vis[y]) continue;
deep[y]=deep[x]+1; //核心语句
dfs(y);
}
}
5.找树的重心·
//pos维护树的重心。
void dfs(int x){
vis[x]=1;
size[x]=1;
int max_part=0;
for(int i=head[x];i;i=edge[i].next){
int y=edge[i].to;
if(vis[y])continue;
dfs(y);
size[x]+=size[y];
max_part=max(max_part,size[y]);
}
max_part=max(max_part,n-size[x]);
if(max_part < ans){
ans=max_part;
pos=x;
}
}
6.图的连通块划分
//cnt维护连通块编号,vis[]记录各节点所属连通块
void dfs(int x){
vis[x]=cnt;
for(int i=head[x];i;i=edge[i].next){
int y=edge[i].to;
if(vis[y])continue;
dfs(y);
}
}
for(int i=1;i<=n;++i){ //在main()中
if(!vis[i]){
cnt++;
dfs(i);
}
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· Sdcb Chats 技术博客:数据库 ID 选型的曲折之路 - 从 Guid 到自增 ID,再到
· 语音处理 开源项目 EchoSharp
· 《HelloGitHub》第 106 期
· mysql8.0无备份通过idb文件恢复数据过程、idb文件修复和tablespace id不一致处
· 使用 Dify + LLM 构建精确任务处理应用