尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

【学习笔记】tarjan 算法大杂烩

【学习笔记】tarjan 算法大杂烩
📅 发布时间:2026/6/21 15:28:10

前置知识

啊嘿嘿,第三次学习 tarjan 终于是给我学明白了。
先来看一下 dfs 树上的三种边:

  • 树边:从父亲连向儿子的边
  • 返祖边:从儿子连向祖先的边
  • 横叉边:除了前两种边之外的边

tarjan 算法中常用的两个数组:

  • \(dfn_i\):表示 \(i\) 的时间戳,即第几个被遍历到
  • \(low_i\):表示 \(i\) 只经过最多一条返祖边到达的最小时间戳

下面正片开始!

有向图的 tarjan 算法

求强连通分量

这个好像是 tarjan 算法在有向图中的唯一常见应用吧~

强连通定义

对于有向图中的一个联通子图 \(G(V,E)\),若子图中的任意两点之间都是可以到达的,则称 \(G(V,E)\) 是一个强连通分量

实现

对着代码理解吧~
初始化:dfn[u] = low[u] = ++tim 显然一个点不经过任何边可以到达的最小时间戳是他自己

if(!dfn[v]){		tarjan(v);low[u] = min(low[u], low[v]);
}
else if(in[v]) low[u] = min(low[u], dfn[v]);

如果当前点的时间戳没有被算过就说明是树边,否则就是非树边。
对于一条非树边只能用 \(v\) 的 \(dfn\) 去更新当前的 $low#,否则可以用 \(low\) 来更新当前点的 \(low#\)。
注意,有向图中的 dfs 树可能会出现横叉边的情况,而横叉边是不可以用来更新 \(low\) 的,所以要特判(用是否在栈内,即是否属于当前子树来判断)。

相关新闻

  • 【每日一面】对 Promise.race 的理解
  • 在AI技术唾手可得的时代,挖掘新需求成为制胜关键——某知名1位量化AI框架需求探索
  • 2025 年幕墙灯饰画,灯饰画设计,背胶灯饰画厂家最新推荐,聚焦资质、案例、售后的五家机构深度解读

最新新闻

  • 2026年紫铜块回收新趋势:变废为宝的财富密码 - 品牌优选官
  • Java异常处理实战:从面试题到生产级故障治理
  • 2026年EI论文辅导机构哪家强?实测10家机构,权威性、性价比深度解析 - 艾德思Editsprings
  • Hermes大模型网关本地部署指南:Docker+Rust双轨实战
  • 2026年研究生论文辅导保过机构TOP10:口碑、师资、成功率全维度实测! - 艾德思Editsprings
  • LlamaFactory训练管线深度解析:从数据加载到损失计算的全流程

日新闻

  • 2026速览惠州叛逆青少年学校前十大排名名单出炉 - 武汉中职最新信息发布
  • 2026上饶白蚁消杀哪家好?15年本土2大权威白蚁防治公司推荐(金盾虫控/青蚁卫士) - 我叫一
  • 天龙八部单机版终极数据管理工具:5个技巧快速掌握游戏数据编辑

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号