算法7-10:拓扑排序
2015-03-22 20:32
471 查看
在一个软件project项目中,有些任务须要在另外一个任务完毕之后才干完毕,这样的任务在软件project中是很常见的。下图就展示了一个软件项目的依赖情况。
这张图很明显,就是一张有向图。那么,如今问题就来了,怎样输出任务的完毕顺序呢?
这个问题有一个前提条件,就是有向图中不能出现回路。
算法的基本思想就是在每次dfs返回时将顶点增加到返回结果中。
所以代码能够这样写:
回路检測在Java中有应用的。
比方一段Java代码写成这样,循环继承,那么编译的时候就会报错。
在微软的Excel中也有应用,比方三个格子中含有循环的引用,这时候就会出现错误消息。
这张图很明显,就是一张有向图。那么,如今问题就来了,怎样输出任务的完毕顺序呢?
这个问题有一个前提条件,就是有向图中不能出现回路。
算法的基本思想就是在每次dfs返回时将顶点增加到返回结果中。
所以代码能够这样写:
import java.util.Stack; public class DepthFirstOrder { private boolean[] visited; private Stack<Integer> postOrder = new Stack<Integer>(); public DepthFirstOrder(Graph G) { visited = new boolean[G.V()]; for (int v = 0; v < G.V(); v++) { // 注意:这句话不能遗漏。这句话保证了全部的任务都可以被运行到。 dfs(G, v); } } public Iterable<Integer> sort() { return postOrder; } private void dfs(Graph G, int s) { visited[s] = true; for (int i : G.adj(s)) { // 注意:这个地方是迭代邻居顶点而不是全部顶点 if (!visited[s]) { dfs(G, i); } } postOrder.add(s); } }
回路检測
这个算法还能够找出一个有向图中是否含有回路。回路检測在Java中有应用的。
比方一段Java代码写成这样,循环继承,那么编译的时候就会报错。
public class A extends B { } public class B extends C { } public class C extends A { }
在微软的Excel中也有应用,比方三个格子中含有循环的引用,这时候就会出现错误消息。
相关文章推荐
- 算法与数据结构基础10:C++实现——拓扑排序
- 算法8-10:最短路径算法之拓扑排序
- 程序员面试题精选100题(10)-排序数组中和为给定值的两个数字[算法]
- 算法_10 : 图算法_6: 平面图
- 短网址算法——之 10进制与62进制转换
- 算法-有向环和拓扑排序
- 图基本算法 拓扑排序(基于邻接表的dfs实现)
- 算法分析与设计课程10——523. Continuous Subarray Sum
- 图像检测算法Halcon 10的使用
- Windows 10新压缩算法:32位/64位占用空间可节省1.5GB/2.6GB
- 算法分析与设计week10--349. Intersection of Two Arrays
- SQL Server 索引基础知识(10)----Join 时的三种算法简介
- 拓扑排序 - 数据结构和算法66
- 拓扑排序的算法实现
- 拓扑排序+最短路径(无环加权有向图最短路径算法)
- 20 世纪 10 大算法
- 算法竞赛入门经典 习题2-10 排列(permutation)
- UVA 10305 Ordering Tasks(拓扑排序入门)【刘汝佳算法入门经典例6-15】
- (10)数据挖掘算法之CART
- 【数据结构】算法7.12 AOV-网 拓扑排序