news 2026/5/28 11:35:25

Tarjan算法图论全家桶系列--边双联通分量(eDCC)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Tarjan算法图论全家桶系列--边双联通分量(eDCC)

边双联通分量(eDCC)

定义

在无向图G=(V,E)中,如果删除任意一条边后,子图仍然连通,则称这个子图是边连通的。
边双连通分量(Edge Biconnected Component, eDCC):图的极大边连通子图。

重要性质:

边双连通分量内部没有割边(桥)
不同的边双连通分量之间通过割边连接
每个节点属于且只属于一个边双连通分量
边双连通分量可以缩点,形成一棵树(每个分量作为一个节点,割边作为树边)

Tarjan算法求边双连通分量

  1. 算法核心思想
    Tarjan算法基于深度优先搜索(DFS),在求割边算法的基础上稍作扩展。核心思想是:
    首先找出所有的割边
    然后删除割边,剩下的每个连通块就是一个边双连通分量
    但实际实现中,我们可以在一次DFS中同时完成这两个任务
  2. 算法流程
    与求割边类似,但添加了一个栈来存储当前DFS路径上的节点。当发现一个割边时,并不立即弹出节点,而是在DFS回溯时,根据dfn[u]==low[u]条件来识别一个边双连通分量。
// 核心判断条件if(low[u]==dfn[u]){// 发现一个新的边双连通分量++tot;// 分量计数器加1intv=-1;do{v=stk.top();stk.pop();bel[v]=tot;// 标记v属于第tot个分量}while(v!=u);}

模板

说明:void Clear(int _n)初始化,准备输入的图有n个点。void Add(int u,int v),在u,v之间连一条无向边。void Run()运行Tarjan算法求双联通分量。vector<int> Get():获取bel数组,bel[i]i点属于的边双联通分量编号

template<intN>structeDCC{//已考虑了含重边的情况vector<pair<int,int>>adj[N];vector<int>stk;vector<int>bel;vector<pair<int,int>>bridge;intdfn[N],low[N];intclk,eid,tot,n;//时间,边编号,边双数量voidAdd(intu,intv){//u,v之间连一条无向边++eid;adj[u].push_back({v,2*eid});adj[v].push_back({u,2*eid+1});}voiddfs(intu,intuk){dfn[u]=low[u]=++clk;stk.push_back(u);for(auto&[to,k]:adj[u]){if(k==(uk^1))continue;//不能走回父亲的边if(dfn[to]==0){dfs(to,k);low[u]=min(low[u],low[to]);if(low[to]>dfn[u])bridge.push_back({u,to});}elselow[u]=min(low[u],dfn[to]);}if(dfn[u]==low[u]){++tot;intv=-1;do{v=stk.back();stk.pop_back();bel[v]=tot;}while(v!=u);}}voidClear(int_n){//开始Add()之前先Clear()n=_n;for(inti=0;i<=_n+3;++i)adj[i].clear();stk.clear();bridge.clear();bel.assign(n+3,0);tot=eid=clk=0;fill(dfn,dfn+5+_n,0);fill(low,low+5+_n,0);}voidRun(){for(inti=1;i<=n;++i)if(dfn[i]==0)dfs(i,-1);}vector<int>Get(){returnbel;}};constintmaxn=2*1e5+20;eDCC<maxn>T;
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/26 11:48:25

5分钟快速验证:你的项目是否会有模块导入问题

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个项目预检工具&#xff0c;能够&#xff1a;1. 自动扫描项目中的模块使用情况 2. 识别潜在的导入兼容性问题 3. 生成可视化兼容性报告 4. 提供一键配置修复 5. 支持多种框架…

作者头像 李华
网站建设 2026/5/27 21:01:49

传统vs现代:ARM编译器问题解决效率对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个对比演示工具&#xff0c;左侧展示传统解决ARM编译器版本问题的步骤&#xff1a;手动检查版本、查阅文档、下载安装、配置环境变量、修改makefile等。右侧展示现代解决方案…

作者头像 李华
网站建设 2026/5/26 9:06:02

Python defaultdict新手教程:从零开始学

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个面向初学者的defaultdict教学代码&#xff0c;包含&#xff1a;1) defaultdict的基本概念图解 2) 与普通字典的直观对比 3) 3个循序渐进的示例&#xff08;计数器、分组、树…

作者头像 李华
网站建设 2026/5/26 4:28:58

企业级应用中的数据库连接异常处理实战

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个Spring Boot应用&#xff0c;展示企业级数据库连接异常处理方案。包含&#xff1a;1) 多数据源配置&#xff1b;2) HikariCP连接池优化&#xff1b;3) 自定义异常处理器&am…

作者头像 李华
网站建设 2026/5/28 5:02:04

LobeChat能否支持GraphQL订阅?实时更新功能探索

LobeChat能否支持GraphQL订阅&#xff1f;实时更新功能探索 在构建现代AI聊天应用的今天&#xff0c;用户早已不满足于“发送问题、等待回答”的简单交互模式。越来越多的应用场景要求系统具备实时性&#xff1a;比如多个设备间的消息同步、插件执行进度的动态反馈、语音识别过…

作者头像 李华
网站建设 2026/5/26 7:28:37

传统vs智能:AI如何提升前端面试准备效率10倍

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 构建一个智能前端面试准备系统&#xff0c;功能包括&#xff1a;1) 基于用户技术栈和能力评估的个性化题目推荐 2) 自动记录错题并生成薄弱知识点图谱 3) 智能答案比对&#xff08;…

作者头像 李华