news 2026/4/16 12:53:21

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/4/16 9:18:52

Langchain-Chatchat集成华为NPU与MindIE部署实战

Langchain-Chatchat集成华为NPU与MindIE部署实战 在企业级AI应用落地的浪潮中&#xff0c;如何构建一个既安全可控、又高效稳定的私有化智能问答系统&#xff0c;正成为金融、政务和大型集团关注的核心命题。尤其是在数据合规日益严格的背景下&#xff0c;将大模型能力部署于本…

作者头像 李华
网站建设 2026/4/16 9:20:47

智慧物流 x 智能工厂:双核引擎驱动制造业数智未来

在当今数字化转型的浪潮中&#xff0c;智慧物流系统集成与智能工厂的紧密连接&#xff0c;正成为企业提升竞争力的重要途径。本文将探讨这两者如何通过智能制造解决方案与半导体生产线自动化的协同效应&#xff0c;共同推动生产效率的提升。随着行业需求的发展&#xff0c;通过…

作者头像 李华
网站建设 2026/4/16 9:21:52

printf函数在日志系统中的高级应用

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个简单的日志系统演示项目&#xff0c;展示printf函数的高级用法。功能包括&#xff1a;1) 使用printf输出带时间戳的日志&#xff1b;2) 实现日志级别控制&#xff08;DEBUG…

作者头像 李华
网站建设 2026/4/16 12:34:03

传统vs现代:AI如何将数据库错误修复时间缩短90%

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 设计一个效率对比工具&#xff0c;能够&#xff1a;1.模拟传统手动修复PostgreSQL错误的流程&#xff1b;2.展示AI辅助修复的流程&#xff1b;3.记录并比较两种方式的时间消耗&…

作者头像 李华
网站建设 2026/4/16 10:59:45

Qwen3-8B批量推理实战:Transformers pipeline应用

Qwen3-8B批量推理实战&#xff1a;Transformers pipeline应用 在当前大模型落地加速的背景下&#xff0c;如何在有限硬件资源下高效运行高性能语言模型&#xff0c;成为开发者面临的核心挑战之一。通义千问3系列中的 Qwen3-8B 模型&#xff0c;以80亿参数实现了接近更大规模模…

作者头像 李华
网站建设 2026/4/16 12:36:07

C语言之判断字符串是否为回文

题目描述 输入一个字符串&#xff0c;输出该字符串是否回文。回文是指顺读和倒读都一样的字符串。 输入格式 输入一行字符串&#xff0c;长度小于 100。 输出格式 如果字符串是回文&#xff0c;输出 yes&#xff1b;否则&#xff0c;输出 no。 输入abcdedcba 输出 yes /* by 0…

作者头像 李华