博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据结构课程笔记_拓扑排序
阅读量:6412 次
发布时间:2019-06-23

本文共 464 字,大约阅读时间需要 1 分钟。

何谓拓扑排序?

  由某个集合上的一个偏序得到该集合上的一个全序,这个操作叫做拓扑排序。

 

如何得到一个有向图的拓扑排序?

  按照有向图给出的次序关系,将图中顶点排成一个线性序列,对于有向图中没有限定次序关系的顶点,则可以人为加上任意的次序关系,由此所得顶点的线性序列称之为拓扑有序序列。

 

如何进行拓扑排序?

  1.从有向图中选取一个没有前驱的顶点;

  2.从有向图中删去此顶点以及所有以它为尾的弧;

  重复上述两步直至图空,或者图中找不到无前驱的顶点为止,后一种情况说明图中有环。

 

算法中需要用定量描述代替定性概念:

  没有前驱的顶点=入度为零的顶点;

  删除顶点以及以它为尾的弧=弧头顶点的入度减1;

 

数据结构课程中的实现:

采用邻接表作有向图的存储结构,且在头结点中增加一个存放顶点入度的数组(indegree).为避免每次都要搜索入度为零的顶点,在算法中设置一个“栈”,以保存“入度为零”的顶点。

 

转载于:https://www.cnblogs.com/jasonlixuetao/p/5499503.html

你可能感兴趣的文章
Android性能优化之TraceView和Lint使用详解
查看>>
linux centos7.2 安装mysq,nginx,php
查看>>
intellij IDEA配置tomcat
查看>>
myrocks之事务处理
查看>>
mysql分区
查看>>
基于pgrouting的路径规划之一
查看>>
Java设计模式(一)----单例模式
查看>>
LBS核心技术解析
查看>>
Unity5 新功能解析--GI(全局光)
查看>>
Servlet url-pattern /与/*区别
查看>>
Fible Channel over Convergence Enhanced Ethernet talk about
查看>>
讨论:今日头条适配方案使用中出现的问题
查看>>
自编码器-mnist-fullyconnected
查看>>
CSS3 3D翻转动画
查看>>
JS无形装逼,最为致命
查看>>
sequelize如何使用原生语句
查看>>
分享几个CSS和JS相关的网站or文章
查看>>
每个人都应该了解的金融小知识 -- 利率计算 (含一道码农面试题)
查看>>
解决html中input的placeholder的颜色,点击时消失,input点击时样式的问题
查看>>
android 关于先登录成功后再进入目标界面的思考
查看>>