news 2026/6/26 18:03:18

Tarjan算法图论全家桶--点双联通分量

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Tarjan算法图论全家桶--点双联通分量

定义

在无向图G=(V,E)中,如果删除任意一个节点(及其关联的边)后,子图仍然连通,则称这个子图是点连通的。

点双连通分量(Vertex Biconnected Component, vDCC):图的极大点连通子图

重要性质

  1. 点双连通分量内部没有割点
  2. 不同的点双连通分量之间通过割点连接
  3. 一个割点可以属于多个点双连通分量
  4. 点双连通分量和割点一起可以构成块-割点树

Tarjan算法求点双连通分量

1. 算法核心思想

Tarjan算法基于深度优先搜索(DFS),是求割点算法的扩展。核心思想是:

  1. 在DFS过程中维护一个,存储当前搜索路径上的节点
  2. 当发现一个割点时,从栈中弹出节点直到当前节点的子节点
  3. 弹出的节点与割点一起构成一个点双连通分量
  4. 注意:割点不出栈,因为它可能属于多个分量

2. 算法流程

// 核心判断条件if(low[to]>=dfn[u]){// 发现割点u的一个vDCC++tot;// 新增一个点双连通分量intv;do{v=stk.top();stk.pop();Dcc[tot].push_back(v);}while(v!=to);// 弹出直到子节点toDcc[tot].push_back(u);// 割点u也加入分量}

模板

说明:void Run(int _n,vector<int> adj[])传入总点数nvector<int>[]邻接表adj,运行Tarjan求点双联通分量。vector<int> Dcc[N]Dcc[i]存了编号为i的vDcc内所有的点.

template<intN>structvDCC{intdfn[N],low[N];constvector<int>*adj;vector<int>stk,cut;vector<int>Dcc[N];//1~tot,Dcc[i],编号为i的vDcc内的点.inttot;//vDcc数量intn,clk,root;voiddfs(intu){dfn[u]=low[u]=++clk;stk.push_back(u);intcnt=0;for(intto:adj[u]){if(dfn[to]==0){dfs(to);low[u]=min(low[u],low[to]);if(low[to]>=dfn[u]){++cnt;++tot;intv;do{v=stk.back();stk.pop_back();Dcc[tot].emplace_back(v);}while(v!=to);Dcc[tot].emplace_back(u);}}elselow[u]=min(low[u],dfn[to]);}if((u!=root&&cnt>=1)||cnt>=2)cut[u]=true;if(cnt==0&&u==root)Dcc[++tot].pb(u);}voidRun(int_n,vector<int>adj[]){n=_n;this->adj=adj;clk=tot=0;fill(dfn,dfn+n+3,0);fill(low,low+n+3,0);stk.clear();cut.assign(n+3,false);for(inti=0;i<=n+3;++i)Dcc[i].clear();for(inti=1;i<=n;++i){if(dfn[i]==0){root=i;dfs(i);}}}};constintmaxn=2*1e5+20;vDCC<maxn>T;
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 1:21:14

psd转ugui

背景&#xff1a;当前2d小团队还是存在很多靠人手拼ui的情况&#xff0c;之前我也做了相关的工具可以对着设计图去拼ui但是还是感觉有点繁琐&#xff0c;程序员花大量时间在ui的拼接上实在是不太明智。于是参考网上的psd2ugui插件我改了一些便携方法&#xff0c;原作者的工具操…

作者头像 李华
网站建设 2026/6/24 23:48:22

AI+SNS Marketing 跨境营销实操:如何在社媒渠道提高外贸引流转化

掌握AISNS Marketing 跨境营销实操&#xff0c;易营宝教你用智能建站与AI工具提升外贸引流转化率。   本文面向信息调研者、企业决策者、项目管理者与经销商等B2B读者&#xff0c;聚焦如何在社媒渠道导流、筛选高质量线索并实现外贸网站的持续转化优化。当前外贸获客面临成本…

作者头像 李华
网站建设 2026/6/23 13:38:08

web APIs 第四天

&#xff08;详细资料和相关课程可搜b站黑马程序员&#xff09; 一、日期对象 1.日期对象 日期对象&#xff1a;用来表示时间的对象作用&#xff1a;可以得到当前系统时间1.1实例化在代码中new关键字&#xff0c;一般这个操作称为实例化创建一个时间对象并获取时间new Date()…

作者头像 李华
网站建设 2026/6/25 6:42:55

Qt菜单项切换主界面

下面是代码截图mainwindow.h#ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow>QT_BEGIN_NAMESPACE namespace Ui { class MainWindow; } QT_END_NAMESPACEclass file1; class file2; class edit01; class edit02; class gjxm; class MainWindow : public…

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

程序员转行大模型指南:2025年最佳时机,抓住这些岗位和选择方法,吃下第一波红利!

一、大模型热门岗位 1. 模型研发工程师 模型研发工程师的核心任务是设计和开发新的深度学习模型架构。这包括但不限于研究最新的模型论文&#xff0c;理解并复现复杂的模型结构&#xff0c;以及在此基础上进行创新改进。此外&#xff0c;工程师还需要关注模型训练过程中的性能…

作者头像 李华