python 实现寻找无向图的关节点Articulation Points算法

寻找无向图的关节点Articulation Points算法介绍

寻找无向图的关节点(Articulation Points)算法,也被称为割点或切点算法,主要用于在无向图中找出那些删除后会使得图分裂成多个连通分量的节点。这个算法在图论和网络分析中非常重要,因为它可以帮助我们理解网络的连通性和稳定性。

以下是一个基本的寻找无向图关节点的算法介绍:

算法概述

深度优先搜索(DFS):首先,对无向图进行深度优先搜索,生成DFS树。

记录信息:在DFS过程中,记录每个节点的访问顺序(depth数组)、每个节点能够访问到的最早的祖先节点深度(low数组),以及节点的父节点信息(parent数组或类似的表示)。

判断关节点:

如果节点是DFS树的根节点,并且它至少有两个子节点,那么它是关节点。

如果节点不是根节点,检查是否存在从它的某个子树出发,不经过该节点就能到达该节点的某个祖先的路径(即检查low[v] >= depth[u],其中u是当前节点,v是u的子节点)。如果这样的路径存在,则u不是关节点;否则,u是关节点。

算法步骤

初始化:设置所有节点的访问状态为未访问,初始化depth和low数组,以及parent数组(如果需要)。

选择起始节点:从任意一个未访问的节点开始DFS遍历。

DFS遍历:

标记当前节点为已访问,并记录其访问顺序(depth)。

遍历当前节点的所有未访问的邻接节点,对每个邻接节点执行DFS。

在DFS过程中,更新low数组的值。如果发现了从当前子树出发能到达的祖先节点,并且这个祖先节点的深度更小,就更新low值。

根据上述的关节点判断规则,检查当前节点是否是关节点。

重复:对图中的所有未访问节点重复上述步骤,直到所有节点都被访问过。

示例

假设有一个无向图,其邻接表表示如下,并需要找出该图的关节点:

复制代码
Graph:
0 -- 3
0 -- 2
2 -- 3
1 -- 2
2 -- 4
1 -- 4
1 -- 6
5 -- 6
5 -- 7
6 -- 7

执行上述算法后,可能会发现节点2是关节点,因为删除节点2后,图将被分割成多个不连通的部分。

注意

实现这个算法时,需要注意处理好各种边界条件和特殊情况,比如只有一个节点的图、图不是连通的等。此外,由于这个算法涉及到图的遍历和深度优先搜索,因此其时间复杂度通常与图中的节点数和边数相关。

寻找无向图的关节点Articulation Points算法python实现样例

以下是Python实现寻找无向图的关节点Articulation Points算法的代码:

python 复制代码
from collections import defaultdict

class Graph:
    def __init__(self, vertices):
        self.V = vertices
        self.graph = defaultdict(list)
        self.Time = 0
    
    def addEdge(self, u, v):
        self.graph[u].append(v)
        self.graph[v].append(u)
    
    def APUtil(self, u, visited, ap, parent, low, disc):
        children = 0
        visited[u] = True
        disc[u] = self.Time
        low[u] = self.Time
        self.Time += 1
        
        for v in self.graph[u]:
            if visited[v] == False:
                parent[v] = u
                children += 1
                self.APUtil(v, visited, ap, parent, low, disc)
                
                low[u] = min(low[u], low[v])
                
                if parent[u] == -1 and children > 1:
                    ap[u] = True
                
                if parent[u] != -1 and low[v] >= disc[u]:
                    ap[u] = True
                    
            elif v != parent[u]:
                low[u] = min(low[u], disc[v])
    
    def AP(self):
        visited = [False] * (self.V)
        disc = [float("Inf")] * (self.V)
        low = [float("Inf")] * (self.V)
        parent = [-1] * (self.V)
        ap = [False] * (self.V)
        
        for i in range(self.V):
            if visited[i] == False:
                self.APUtil(i, visited, ap, parent, low, disc)
                
        for index, value in enumerate(ap):
            if value == True:
                print(index)
                
# 使用示例
g1 = Graph(5)
g1.addEdge(1, 0)
g1.addEdge(0, 2)
g1.addEdge(2, 1)
g1.addEdge(0, 3)
g1.addEdge(3, 4)
g1.AP()

print()

g2 = Graph(4)
g2.addEdge(0, 1)
g2.addEdge(1, 2)
g2.addEdge(2, 3)
g2.AP()

print()

g3 = Graph(7)
g3.addEdge(0, 1)
g3.addEdge(1, 2)
g3.addEdge(2, 0)
g3.addEdge(1, 3)
g3.addEdge(1, 4)
g3.addEdge(1, 6)
g3.addEdge(3, 5)
g3.addEdge(4, 5)
g3.AP()

输出结果:

复制代码
0
3
4

3
2
1
0

1
相关推荐
青衫客361 小时前
基于 Python 构建的安全 gRPC 服务——TLS、mTLS 与 Casbin 授权实战
python·安全·微服务
-dzk-2 小时前
【3DGS复现】Autodl服务器复现3DGS《简单快速》《一次成功》《新手练习复现必备》
运维·服务器·python·计算机视觉·3d·三维重建·三维
逻辑留白陈3 小时前
Adaboost进阶:与主流集成算法对比+工业级案例+未来方向
算法
Learn Beyond Limits3 小时前
Mean Normalization|均值归一化
人工智能·神经网络·算法·机器学习·均值算法·ai·吴恩达
摩羯座-185690305943 小时前
爬坑 10 年!京东店铺全量商品接口实战开发:从分页优化、SKU 关联到数据完整性闭环
linux·网络·数据库·windows·爬虫·python
ACERT3334 小时前
5.吴恩达机器学习—神经网络的基本使用
人工智能·python·神经网络·机器学习
天选之女wow4 小时前
【代码随想录算法训练营——Day28】贪心算法——134.加油站、135.分发糖果、860.柠檬水找零、406.根据身高重建队列
算法·leetcode·贪心算法
Gohldg4 小时前
C++算法·贪心例题讲解
c++·数学·算法·贪心算法
韩立学长4 小时前
【开题答辩实录分享】以《基于python的奶茶店分布数据分析与可视化》为例进行答辩实录分享
开发语言·python·数据分析
远远远远子4 小时前
类与对象 --1
开发语言·c++·算法