无前趋的顶点优先的拓扑排序方法(JAVA)(转载http://128kj.iteye.com/blog/1706968)
该方法的每一步总是输出当前无前趋(即人度为零)的顶点,其抽象算法可描述为:
NonPreFirstTopSort(G){//优先输出无前趋的顶点
while(G中有人度为0的顶点)do{
从G中选择一个人度为0的顶点v且输出之;
从G中删去v及其所有出边;
}
if(输出的顶点数目<|V(G)|)
//若此条件不成立,则表示所有顶点均已输出,排序成功。
Error("G中存在有向环,排序失败!");
}
- import java.util.Arrays;
- import java.util.List;
- import java.util.ArrayList;
- import java.util.Stack;
- public class Graph {
- int vertexNum; //图的顶点数
- ArrayList<ArrayList<Integer>> table; //图的邻接表,table.get(i)存放与i邻接的顶点
- Stack<Integer> stack; //存放入度为0的顶点
- int[] result; //拓朴排序的结果
- int[] in;// 入度,in[i]表示顶点i的入度
- /**
- *
- * 构造一个图
- *
- * @param num
- * 图的顶点数
- *
- */
- public Graph(int num) {
- vertexNum = num;
- table = new ArrayList<ArrayList<Integer>> (vertexNum);
- ;i<vertexNum;i++)
- table.add(new ArrayList<Integer>());
- stack = new Stack<Integer>();
- result = new int[vertexNum];
- in = new int[vertexNum];
- }
- /**
- * 向图中添加无向边
- *
- * @param I
- * 边的一个顶点
- * @param J
- * 边的另一个顶点
- * @return 是否添加成功
- */
- public boolean addEdge(int I, int J) {
- /**
- * 判断用户输入的是否是一个顶点,如果是,则返回flase,添加不成功
- */
- if (J == I) {
- return false;
- }
- /**
- * 判断所输入的顶点值是否在图所顶点范围值内,如果不在,则提示顶点不存在
- *
- */
- ) {
- /**
- *
- * 判断边是否存在
- */
- if (isEdgeExists(I, J)) {
- return false;
- }
- /**
- * 添加边,将孤头的入度加1
- */
- table.get(I).add(J);
- in[J]++;
- return true;
- }
- return false;
- }
- /**
- * 判断有向边是否存在
- *
- * @param i
- * 要查询的有向边的一个孤尾
- * @param j
- * 要查询的有向边的另一个孤头
- * @return 边是否存在,false:不存在,true:存在
- */
- public boolean isEdgeExists(int i, int j) {
- /**
- * 判断所输入的顶点值是否在图所顶点范围值内,如果不在,则提示顶点不存在
- *
- */
- ) {
- if (i == j) {
- return false;
- }
- /**
- * 判断i的邻接结点集是否为空
- */
- if (table.get(i) == null) {
- return false;
- }
- /**
- * 判断这条边是否存在,如果存在,则提示边已经存在
- */
- ; q < table.get(i).size(); q++) {
- if (((Integer) table.get(i).get(q)).intValue() == j) {
- System.out.println("顶点" +i+"和"+"顶点"+j+ "这两点之间存在边");
- return true;
- }
- }
- }
- return false;
- }
- public void TopSort() { //无前趋的顶点优先的拓扑排序方法
- ; i < vertexNum; i++) //无前趋的顶点入栈
- )
- stack.push(i);
- ;
- while (!stack.isEmpty()) {
- result[k] = (Integer) stack.pop(); //弹出一个无前趋的顶点,并放入拓扑排序的结果集
- if (table.get(result[k]) != null) { //这个顶点的邻接表非空
- ; j < table.get(result[k]).size(); j++) {
- int temp = (Integer) table.get(result[k]).get(j);
- //对result[k]每一个邻接点进行入度减1操作
- ) { //如果temp的入度为0,进栈.
- stack.push(temp);
- }
- }
- }
- k++;
- }
- if (k < vertexNum) {
- System.out.println("有回路");
- );
- }
- }
- public int[] getResult() {
- return result;
- }
- }
测试: 
- import java.util.List;
- public class GraphTest {
- public static void main(String args[]){
- );
- );
- );
- );
- );
- );
- );
- );
- );
- );
- graph.TopSort();
- int[] list = graph.getResult();
- System.out.println("拓扑排序的结果为:");
- for(int i : list){
- System.out.print(i+" ");
- }
- }
- }
运行:
C:\>java GraphTest
拓扑排序的结果为:
4 2 1 3 5 0
下载源码
- graphtoposort.zip (1.8 KB)
- 下载次数: 0
无前趋的顶点优先的拓扑排序方法(JAVA)(转载http://128kj.iteye.com/blog/1706968)的更多相关文章
- 有向图的拓扑排序算法JAVA实现
一,问题描述 给定一个有向图G=(V,E),将之进行拓扑排序,如果图有环,则提示异常. 要想实现图的算法,如拓扑排序.最短路径……并运行看输出结果,首先就得构造一个图.由于构造图的方式有很多种,这里假 ...
- 算法笔记_023:拓扑排序(Java)
目录 1 问题描述 2 解决方案 2.1 基于减治法实现 2.2 基于深度优先查找实现 1 问题描述 给定一个有向图,求取此图的拓扑排序序列. 那么,何为拓扑排序? 定义:将有向图中的顶点以线性方式进 ...
- tsort - 拓扑排序
tsort - 拓扑排序 本文链接:http://codingstandards.iteye.com/blog/834572 (转载请注明出处) 用途说明 tsort命令通常用于解决一种逻辑问题, ...
- 有向无环图的应用—AOV网 和 拓扑排序
有向无环图:无环的有向图,简称 DAG (Directed Acycline Graph) 图. 一个有向图的生成树是一个有向树,一个非连通有向图的若干强连通分量生成若干有向树,这些有向数形成生成森林 ...
- 大数据工作流任务调度--有向无环图(DAG)之拓扑排序
点击上方蓝字关注DolphinScheduler(海豚调度) |作者:代立冬 |编辑:闫利帅 回顾基础知识: 图的遍历 图的遍历是指从图中的某一个顶点出发,按照某种搜索方法沿着图中的边对图中的所有顶点 ...
- 关于拓扑排序(topologicalsort)
假设我们有一组任务要完成,并且有些任务要在其它任务完成之后才能开始,所以我们必须非常小心这些任务的执行顺序.如果这些任务的执行顺序足够简单的话,我们可以用链表来存储它们,这是一个很好的方案,让我们可以 ...
- 有向图的拓扑排序的理解和简单实现(Java)
如果图中存在环(回路),那么该图不存在拓扑排序,在这里我们讨论的都是无环的有向图. 什么是拓扑排序 一个例子 对于一部电影的制作过程,我们可以看成是一个项目工程.所有的工程都可以分为若干个" ...
- 拓扑排序(topsort)
本文将从以下几个方面介绍拓扑排序: 拓扑排序的定义和前置条件 和离散数学中偏序/全序概念的联系 典型实现算法解的唯一性问题 Kahn算法 基于DFS的算法 实际例子 取材自以下材料: http://e ...
- hdu4324 Triangle LOVE (拓扑排序)
这是一道最简单的拓扑排序题,好久没看这个算法了! 有点生疏了! 后附上百度的资料; #include<stdio.h> #include<string.h> int in[50 ...
随机推荐
- docker18.ce harbor 安装
Harbor 是什么? harbor VMware 开发的一个容器镜像仓库,harbor的功能提供用户权限管理.镜像复制等功能,提高使用的registry的效率. 安装最新版的docker可以参考d ...
- easyui学习笔记14-拓展的基本验证规则
/** * 扩展的基本校验规则, */ $.extend($.fn.validatebox.defaults.rules, { minLength : { // 判断最小长度 validator : ...
- Java数组、集合的三种遍历方式(包懂)
1 for循环 for(int i = 0;i<arr.length;i++){ System.out.print(arr[i]+" "); } 2 foreach循环,这种 ...
- Python接口自动化--requests 2
# _*_ encoding:utf-8 _*_ import json import requests #post请求 payload = {"cindy":"hell ...
- 关于ARMv8指令的几个问题
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/qianlong4526888/article/details/27512629 NOTE:下面内容仅 ...
- [Luogu 3707] SDOI2017 相关分析
[Luogu 3707] SDOI2017 相关分析 前言 Capella 和 Frank 一样爱好天文学. 她常在冬季的夜晚,若有所思地望着东北方上空的五边形中,最为耀眼的一个顶点. 那一抹金黄曾带 ...
- Scala学习之路 (十)Scala的Actor
一.Scala中的并发编程 1.Java中的并发编程 ①Java中的并发编程基本上满足了事件之间相互独立,但是事件能够同时发生的场景的需要. ②Java中的并发编程是基于共享数据和加锁的一种机制,即会 ...
- Mac svn使用学习-2-服务端
2.在mac环境下搭建一个SVN服务器环境 1)创建一个名为myCode的仓库——svnadmin命令 格式: svnadmin SUBCOMMAND REPOS_PATH [ARGS & O ...
- OpenCV——图像的载入、显示、输出到文件和滑动条、鼠标操作
图像的载入.显示.输出到文件和滑动条 滑动条 示例: 鼠标操作
- [POI2007]旅游景点atr BZOJ1097
分析: 我们可以考虑,因为我们必须经过这些节点,那么我们可以将它状压,并且我们因为可以重复走,只是要求停顿前后,不要求遍历前后,那么我们之间存一下点与点之间的最短路,之后每次转移一下就可以了. f[i ...