使用python处理有向图、偏序和拓扑排序的一些工具

digraphtools的Python项目详细描述


处理有向无环图、偏序和 用python进行拓扑排序

有向图工具是一种使用dags和partial的轻量级方法。 在轻量级中表示、排序和遍历依赖树的顺序 太好了。

代码位于github上的https://github.com/dbasden/python-digraphtools

图形表示

图表

图被表示为将节点映射到列表的dict 通过该节点的传出边连接的节点。

例如

graph = { 1: [2,3],
2: [3], 3: [] }

是由边(1,2)(1,3)(2,3)表示的DAG 其中边2的形式是(从,到)

deptools中有helper方法可以从 边列表,反之亦然

二元关系

如果DAG表示依赖项,则取边(1,2) 意思是“1依赖于2”,这是从二进制关系向后的。 (1,2)是关系2p 1

拓扑排序

有两种方法可以生成 依赖项(即必须在中处理订单项以满足依赖项 要求:

deptools.dfs_tosport_traversal

deptools.dfs_topsort_遍历将获取一个图形并在 单个有效的拓扑排序顺序

deptools.tosport.vr_tosport

deptools.tosport.vr_tosport将生成所有有效的线性扩展/ 给定初始“种子”线性扩展的拓扑序(例如 由deptools.dfs_tosport_traversal生成的)。

该方法不接受deptools使用的图形格式作为输入, 但是它确实有一个helper方法从 部分顺序集(可以使用 开发工具)。

请参阅tosport.py和test/test_tosport.py中的示例以了解如何执行此操作。

作者

DigraphTools最初由David Basden编写

谢谢

感谢Yaakov L.Varol和Doron Rotem的算法设计 在tosport.py中

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java在ArrayList中比较数字   java在Kotlin中使异步调用同步   让“Scala编程”junit示例在IntelliJ中工作的java问题   java Servlet侦听器未在ContextListener中设置属性   将Microsoft SQL Server数据库连接到我的Java项目   加载资源时出现java“需要注册工厂”异常   java如何使用POI检查excel中的重复记录?   java如何更改机器生成的代码   java如何确保重写的方法是同步的   用Spring编写Hibernate时的java XML奥秘   java管理mysql数据库中存储的用户权限   java如何运行。来自Javascript的jar方法   java我想在Web应用程序中进行身份验证&对桌面应用程序使用相同的凭据。我该怎么做?