当前位置: 首页 > news >正文

Tarjan算法图论全家桶系列--割边(桥)

割边定义

在无向图G=(V,E)中,如果一条边e满足:删除e后,图的连通分量数量增加,则称e为割边(Bridge)。

重要性质

  • 割边一定是树边(在DFS生成树中的边)
  • 有重边(多重边)的边不可能是割边
  • 割边对应的两个端点中,至少有一个是割点(除非是悬挂边)

Tarjan算法求割边

1. 算法核心思想

Tarjan算法基于深度优先搜索(DFS),与求割点的算法类似,但判断条件有所不同。核心仍然是两个数组:

  • dfn[u]:节点u的DFS访问顺序(时间戳)
  • low[u]:从u出发,不经过DFS树中的父节点,能到达的最小dfn值

2. 判断割边的条件

对于一条树边(u, v)(其中u是v的父节点),如果满足:
low[v] > dfn[u]
那么(u, v)是一条割边。

解释

  • low[v]表示从v出发(不经过v→u这条边)能到达的最小时间戳
  • low[v] > dfn[u]意味着v及其后代无法通过任何非树边到达u或u的祖先
  • 因此,如果删除边(u, v),v所在的子图将与图的其余部分完全断开

模板

说明:Run(int _n,vector<int> adj[])传入总点数nvector<int>[]邻接表adj,运行tarjan求割边。vector<pair<int,int>> Get()获取所有割边

template<intN>structCut_edge{//不含重边constvector<int>*adj;vector<pair<int,int>>bridge;intdfn[N],low[N];intclk;voiddfs(intu,intfather){dfn[u]=low[u]=++clk;for(intto:adj[u]){if(to==father)continue;//不能走回父亲的边if(dfn[to]==0){dfs(to,u);low[u]=min(low[u],low[to]);if(low[to]>dfn[u])bridge.push_back({u,to});}elselow[u]=min(low[u],dfn[to]);}}voidRun(int_n,vector<int>adj[]){this->adj=adj;clk=0;bridge.clear();fill(dfn,dfn+5+_n,0);fill(low,low+5+_n,0);for(inti=1;i<=_n;++i)if(dfn[i]==0)dfs(i,-1);}vector<pair<int,int>>Get(){returnbridge;}};constintmaxn=2*1e5+20;Cut_edge<maxn>T;
http://www.cnnetsun.cn/news/63953.html

相关文章:

  • 用VPS快速搭建个人博客原型
  • 5分钟搭建Ollama连接监控原型
  • 15分钟快速验证:CUDA+cuDNN加速效果对比
  • 比手动快10倍:自动化处理TLS证书错误
  • 用LittleFS快速构建物联网设备数据存储原型
  • 传统排错vsAI辅助:解决Ollama错误效率对比
  • 实战:用XUnity翻译为独立游戏添加15种语言支持
  • 5个真实场景下的list转string实战案例解析
  • 1小时打造证书错误监控原型:快马平台实战演示
  • 企业级Tomcat集群安装实战:从单机到高可用部署
  • CAN FD零基础入门:用快马平台10分钟创建第一个项目
  • 30分钟快速开发Win11 C盘清理工具原型
  • 企业级项目实战:Git团队协作代码拉取全流程
  • 如何用AI自动生成LittleFS嵌入式文件系统代码
  • 传统Cron配置 vs AI生成:效率提升10倍的秘密
  • 企业级项目实战:解决Gradle JVM版本冲突的5种方法
  • AI如何帮你快速开发小说阅读App?
  • CppCon 2024 学习:Implementing Particle Filters With Ranges
  • DDS入门指南:零基础搭建第一个分布式通信应用
  • 小白必看:Windows安装FFmpeg图文详解
  • Leaflet中文文档实战:疫情数据可视化地图开发指南
  • AI如何优化锁相环电路设计?
  • OpenMP入门:零基础写出第一个并行程序
  • AI如何帮你快速掌握Modbus TCP协议开发
  • 3分钟搞定Java环境:Cursor vs 传统方式效率对比
  • 3步快速验证你的Adobe弹窗解决方案
  • 深度学习模型加载实战:解决权重加载失败的5种方法
  • 企业级时间同步方案:国内NTP服务器实战部署
  • AI帮你写Git提交信息:告别手动Commit描述
  • 同城自助KTV预约:JAVA线上系统超给力