news 2026/6/15 18:09:27

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/6/15 14:07:20

视频速度控制:节省时间的终极技巧

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个效率分析工具&#xff0c;比较不同视频速度下的观看时间节省情况。开发一个浏览器插件&#xff0c;能够自动分析网页视频内容&#xff0c;推荐最佳观看速度。实现批量处理功…

作者头像 李华
网站建设 2026/6/15 15:20:53

3倍速!微PE安装Win10的极致优化技巧

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个微PE安装优化工具&#xff0c;功能包括&#xff1a;1.自动优化U盘读写性能 2.智能选择最快安装源 3.并行化安装流程 4.安装参数自动优化 5.安装耗时分析和建议。要求能将标…

作者头像 李华
网站建设 2026/6/15 15:17:27

CallerRunPolicy vs AbortPolicy:性能对比与选择指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个性能对比测试程序&#xff0c;比较CallerRunPolicy和AbortPolicy在不同负载下的表现。要求&#xff1a;1) 可调节的线程池参数和负载压力 2) 统计任务完成率、平均耗时等关…

作者头像 李华
网站建设 2026/6/15 15:20:08

【RealEarthStudio】应用2:数据集渲染任务管理——后端搭建

数据集渲染任务管理——后端搭建引言一、主要功能二、实现步骤2.1 创建App&#xff08;1&#xff09;使用命令行创建App&#xff08;2&#xff09;注册App&#xff08;3&#xff09;配置路由2.2 创建Model&#xff08;1&#xff09;配置媒体文件地址&#xff08;2&#xff09;创…

作者头像 李华
网站建设 2026/6/15 15:36:09

第六十一篇-ComfyUI+V100-32G+GGUF+运行Flux Schnell GGUF

环境 系统&#xff1a;CentOS-7 CPU : E5-2680V4 14核28线程 内存&#xff1a;DDR4 2133 32G * 2 显卡&#xff1a;Tesla V100-32G【PG503】 (水冷) 驱动: 535 CUDA: 12.2 ComfyUI version: 0.4.0 ComfyUI frontend version: 1.34.8系统软件信息 系统信息 OS linux Python Vers…

作者头像 李华