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在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
  • asp之家 网络编程 m.aspxhome.com