Python关于拓扑排序知识点讲解

作者:runoob 时间:2022-09-12 15:04:22 

对一个有向无环图(Directed Acyclic Graph简称DAG)G进行拓扑排序,是将G中所有顶点排成一个线性序列,使得图中任意一对顶点u和v,若边(u,v)∈E(G),则u在线性序列中出现在v之前。

通常,这样的线性序列称为满足拓扑次序(Topological Order)的序列,简称拓扑序列。简单的说,由某个集合上的一个偏序得到该集合上的一个全序,这个操作称之为拓扑排序。

在图论中,由一个有向无环图的顶点组成的序列,当且仅当满足下列条件时,称为该图的一个拓扑排序(英语:Topological sorting):

  • 每个顶点出现且只出现一次;

  • 若A在序列中排在B的前面,则在图中不存在从B到A的路径。

Python关于拓扑排序知识点讲解

实例代码


from collections import defaultdict

class Graph:
def __init__(self,vertices):
 self.graph = defaultdict(list)
 self.V = vertices

def addEdge(self,u,v):
 self.graph[u].append(v)

def topologicalSortUtil(self,v,visited,stack):

visited[v] = True

for i in self.graph[v]:
  if visited[i] == False:
   self.topologicalSortUtil(i,visited,stack)

stack.insert(0,v)

def topologicalSort(self):
 visited = [False]*self.V
 stack =[]

for i in range(self.V):
  if visited[i] == False:
   self.topologicalSortUtil(i,visited,stack)

print (stack)

g= Graph(6)
g.addEdge(5, 2);
g.addEdge(5, 0);
g.addEdge(4, 0);
g.addEdge(4, 1);
g.addEdge(2, 3);
g.addEdge(3, 1);

print ("拓扑排序结果:")
g.topologicalSort()

执行以上代码输出结果为:

拓扑排序结果:

[5, 4, 2, 3, 1, 0]

实例扩展:


def toposort(graph):
in_degrees = dict((u,0) for u in graph) #初始化所有顶点入度为0
vertex_num = len(in_degrees)
for u in graph:
 for v in graph[u]:
  in_degrees[v] += 1  #计算每个顶点的入度
Q = [u for u in in_degrees if in_degrees[u] == 0] # 筛选入度为0的顶点
Seq = []
while Q:
 u = Q.pop()  #默认从最后一个删除
 Seq.append(u)
 for v in graph[u]:
  in_degrees[v] -= 1  #移除其所有指向
  if in_degrees[v] == 0:
   Q.append(v)   #再次筛选入度为0的顶点
if len(Seq) == vertex_num:  #如果循环结束后存在非0入度的顶点说明图中有环,不存在拓扑排序
 return Seq
else:
 print("there's a circle.")
G = {
'a':'bce',
'b':'d',
'c':'d',
'd':'',
'e':'cd'
}
print(toposort(G))

输出结果:

['a', 'e', 'c', 'b', 'd']

来源:https://www.runoob.com/python3/python-topological-sorting.html

标签:Python,拓扑排序
0
投稿

猜你喜欢

  • python实现学员管理系统(面向对象版)

    2022-04-08 12:55:32
  • python监测当前联网状态并连接的实例

    2023-04-19 03:33:19
  • Python简单几步画个钻石戒指

    2023-04-26 13:59:27
  • 关于python中导入文件到list的问题

    2021-03-03 21:46:16
  • Python实现将一个正整数分解质因数的方法分析

    2021-01-09 10:39:29
  • 修改 CentOS 6.x 上默认Python的方法

    2023-08-07 10:02:59
  • 基于关系型数据库引擎的\\XML\\索引技术

    2008-09-05 17:13:00
  • python定时检测无响应进程并重启的实例代码

    2023-11-29 11:00:39
  • Python使用matplotlib实现基础绘图功能示例

    2023-08-31 03:24:02
  • Python使用import导入本地脚本及导入模块的技巧总结

    2022-09-07 15:09:29
  • 交互设计的方法

    2010-08-18 12:32:00
  • 通过实例简单了解Python sys.argv[]使用方法

    2022-09-12 14:14:35
  • XML轻松学习手册(3)XML的术语

    2008-09-05 17:17:00
  • Python面向对象编程基础解析(一)

    2021-08-10 15:05:12
  • 浅谈opencv自动光学检测、目标分割和检测(连通区域和findContours)

    2023-04-15 09:25:18
  • python嵌套字典比较值与取值的实现示例

    2023-12-25 01:28:35
  • python队列Queue的详解

    2022-10-09 16:56:21
  • asp使用Application来统计在线人数方法

    2007-08-13 12:43:00
  • asp截取指定英汉混合字符串_支持中文

    2011-04-19 10:39:00
  • javascript中的关于类型转换的性能优化

    2023-06-26 16:25:48
  • asp之家 网络编程 m.aspxhome.com