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,拓扑排序
0
投稿
猜你喜欢
如何让Python在HTML中运行
2023-06-13 08:21:28
python调用matlab的方法详解
2023-10-18 06:39:02
Python实现监控Nginx配置文件的不同并发送邮件报警功能示例
2023-09-22 11:07:33
mysql实现合并同一ID对应多条数据的方法
2024-01-15 16:19:34
Python PIL读取的图像发生自动旋转的实现方法
2022-05-01 20:29:26
在pyqt5中展示pyecharts生成的图像问题
2023-10-17 10:59:46
在tensorflow中设置使用某一块GPU、多GPU、CPU的操作
2023-07-22 11:37:28
Python实现Sqlite将字段当做索引进行查询的方法
2021-06-05 13:31:51
简单了解Python变量作用域正确使用方法
2022-02-03 04:18:55
基于pip install django失败时的解决方法
2021-06-19 06:01:27
asp清空站点缓存
2009-08-04 18:01:00
thinkPHP中配置的读取与C方法详解
2023-11-14 17:12:35
c# 获取数据库中所有表名称的方法
2024-01-16 18:41:33
Python快速实现一键抠图功能的全过程
2021-03-03 14:58:39
解决mysql安装时出现error Nr.1045问题的方法
2024-01-18 11:34:30
GO必知必会的常见面试题汇总
2023-07-14 01:47:07
五种方法解决 Web2.0设计中的匹配度
2007-09-22 10:58:00
网页表单项Input的高级限制级用法
2008-10-27 16:50:00
Python多层装饰器用法实例分析
2023-08-20 07:34:35
ASP.NET教程第二讲:安装ASP.NET
2007-08-07 11:59:00