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的路径。
实例代码
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,拓扑排序
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python实现学员管理系统(面向对象版)
2022-04-08 12:55:32
python监测当前联网状态并连接的实例
2023-04-19 03:33:19
Python简单几步画个钻石戒指
2023-04-26 13:59:27
![](https://img.aspxhome.com/file/2023/8/94088_0s.gif)
关于python中导入文件到list的问题
2021-03-03 21:46:16
![](https://img.aspxhome.com/file/2023/9/125139_0s.png)
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
![](https://img.aspxhome.com/file/2023/1/109381_0s.png)
Python使用import导入本地脚本及导入模块的技巧总结
2022-09-07 15:09:29
交互设计的方法
2010-08-18 12:32:00
![](https://img.aspxhome.com/file/UploadPic/20108/18/01-52s.jpg)
通过实例简单了解Python sys.argv[]使用方法
2022-09-12 14:14:35
![](https://img.aspxhome.com/file/2023/4/113004_0s.png)
XML轻松学习手册(3)XML的术语
2008-09-05 17:17:00
Python面向对象编程基础解析(一)
2021-08-10 15:05:12
浅谈opencv自动光学检测、目标分割和检测(连通区域和findContours)
2023-04-15 09:25:18
![](https://img.aspxhome.com/file/2023/0/75890_0s.jpg)
python嵌套字典比较值与取值的实现示例
2023-12-25 01:28:35
![](https://img.aspxhome.com/file/2023/5/103615_0s.png)
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