IT编程 > 脚本编程 > Python

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

184人参与2021-01-04

对一个有向无环图(directed acyclic graph简称dag)g进行拓扑排序,是将g中所有顶点排成一个线性序列,使得图中任意一对顶点u和v,若边(u,v)∈e(g),则u在线性序列中出现在v之前。

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

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

实例代码

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']

到此这篇关于python关于拓扑排序知识点讲解的文章就介绍到这了,更多相关python 拓扑排序内容请搜索移动技术网以前的文章或继续浏览下面的相关文章希望大家以后多多支持移动技术网!

您对本文有任何疑问!!点此进行留言回复

推荐阅读

猜你喜欢

图文讲解选择排序算法的原理及在Python中的实现

12-12

Python中使用HTMLParser解析html实例

03-23

浅谈Python中chr、unichr、ord字符函数之间的对比

12-12

python dict.get()和dict['key']的区别详解

12-12

在PyCharm导航区中打开多个Project的关闭方法

06-01

python中装饰器的原理

11-03

python网络爬虫《Http和Https协议》

05-28

python_OS 模块

01-28

热门评论