拓扑排序 淩亂°似流年 2021-12-23 02:43 371阅读 0赞 **拓扑排序:** 拓扑排序是根据离散数学中有关偏序与全序定义的。 ![0_1314168765l7fq.gif][] 若一个集合 X 上的关系 R 是自反的 反对称的和传递的,就称为 R 是集合 X 上的 **偏序关系**。 设 R 是集合 X 上的偏序,若对每个 x ,y 属于 x ,必有 xRy 或 yRx,则称 R 是集合 X 上的全序关系。 直观的讲,偏序就是一个点的集合中只有部分顶点可以确立优先关系。而全序就是点的集合中任意两个顶点都可以确立优先关系,而由某个集合上的一个偏序得到该集合的一个全序的操作就是拓扑排序。 由上图可以看出,能够满足拓扑排序,首先这个图是一个有向无环图,即每一个路径都是有向的,而且其中不行成环,如果形成环就不能进行拓扑排序。 例入上图南阳理工学院课表安排: 课程代号 课程名称 先行课 C1 C2 计算机应用基础,c语言 无 C3 网页制作 C1 C4 C++语言程序设计 C1,C2 C5 数据库技术 C3,C4 C6 汇编语言 C2,C4 C7 嵌入式开发 C4,C5,C6 这就是一个类似课程先后关系的有向图,要我们根据前面的关系把这些科安排在不同的学期(即学习的先后关系)。这就要求我们对他进行一个拓扑排序。 可以看出这个排序的结果是C1,C2,C3,C4,C5,C6,C7 或者是 C2,C1,C4,C6,C3,C7。即排序后的结果不是唯一的。 那么我们怎样实现对这样一个图的拓扑排序呢,我们直到图的常用存法有两种,即临接矩阵和临接表。临接矩阵存稠密图,临接表存稀疏图,先介绍一种通过临接表存储通过DFs思想实现的算法。 从一个没有入度的节点出发,深搜回溯的时候保存最深处的点加到拓扑排序的首部。代码: int map[Max][Max]; int vis[Max],topo[Max]; int m,n; bool Dfs(int u) { vis[u]=-1; for(int v=1;v<=n;v++) { if(map[u][v]) { if(vis[v]<0) {return false;} else if(!vis[v]&&!Dfs(v)) return false; } } vis[u] = 1;topo[--t]=u; return true; } bool toposort() { t=n; memset(vis,0,sizeof(vis)); for(int u=1;u<=n;u++) { if(!vis[u]){ if(!Dfs(u)) return false; } } return true; } ### 裸的拓扑排序的题目:[Uva10305 - Ordering Tasks][] ### /*** *Uva10305拓扑排序 *临接矩阵存图,Dfs搜索回溯 ******/ #include <stdio.h> #include <string.h> #define Max 120 int t; int map[Max][Max]; int vis[Max],topo[Max]; int m,n; bool Dfs(int u) { vis[u]=-1; for(int v=1;v<=n;v++) { if(map[u][v]) { if(vis[v]<0) {return false;} else if(!vis[v]&&!Dfs(v)) return false; } } vis[u] = 1;topo[--t]=u; return true; } bool toposort() { t=n; memset(vis,0,sizeof(vis)); for(int u=1;u<=n;u++) { if(!vis[u]){ if(!Dfs(u)) return false; } } return true; } int main() { while(~scanf("%d%d",&n,&m)) { if(n==0&&m==0) break; memset(map,0,sizeof(map)); for(int i=0;i<m;i++) { int a,b; scanf("%d%d",&a,&b); map[a][b]=1; } if(toposort()) { bool ok=true; for(int i=0;i<n;i++) { if(ok) {printf("%d",topo[i]);ok=false;} else printf(" %d",topo[i]); } printf("\n"); } else printf("No\n"); } return 0; } [0_1314168765l7fq.gif]: /images/20211223/30f2133ec4ca4cfdb0ba9b3a470b2deb.png [Uva10305 - Ordering Tasks]: http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=1246
相关 拓扑排序以及拓扑排序算法 拓扑排序对一个有向无环图(Directed Acyclic Graph简称DAG)G进行拓扑排序,是将G中所有顶点排成一个线性序列,使得图中任意一对顶点u和v,若边<u,v>∈ 小咪咪/ 2023年09月28日 22:58/ 0 赞/ 22 阅读
相关 拓扑排序 拓扑排序是一张AOV网(Activity Of Vertex NetWork),并且是无环的网! 概念: 设G=(V,E)是一个具有n个顶点的有向图,V中的顶点序列V1,V 墨蓝/ 2022年08月05日 13:11/ 0 赞/ 54 阅读
相关 拓扑排序 什么是拓扑排序? 在图论中,拓扑排序(Topological Sorting)是一个有向无环图(DAG, Directed Acyclic Graph)的所有顶点的线性序 冷不防/ 2022年06月09日 05:57/ 0 赞/ 246 阅读
相关 拓扑排序 In this winter holiday, Bob has a plan for skiing at the mountain resort. This ski 悠悠/ 2022年06月08日 06:19/ 0 赞/ 48 阅读
相关 拓扑排序 原文地址:[http://blog.csdn.net/lisonglisonglisong/article/details/45543451][http_blog.csdn.n 曾经终败给现在/ 2022年04月22日 13:00/ 0 赞/ 48 阅读
相关 拓扑排序 拓 扑 排 序 一个较大的工程往往被划分成许多子工程,我们把这些子工程称作活动(activity)。在整个工程中,有些子工程(活动)必须在其它有关子工程完成之后才能开始,也就 小鱼儿/ 2022年04月10日 08:23/ 0 赞/ 266 阅读
相关 拓扑排序 (1)有向无环图 无环的有向图,简称 DAG (Directed Acycline Graph) 图。 有向无环图在工程计划和管理方面的应用:除最简单的情况之外,几 古城微笑少年丶/ 2022年03月18日 12:35/ 0 赞/ 314 阅读
相关 拓扑排序 拓扑排序: 拓扑排序是根据离散数学中有关偏序与全序定义的。 ![0_1314168765l7fq.gif][] 若一个集合 X 上的关系 R 是自反的 反 淩亂°似流年/ 2021年12月23日 02:43/ 0 赞/ 372 阅读
相关 拓扑排序 拓扑排序 题目做的烦,题解写着玩 [POJ 2762 Going from u to v or from v to u?][POJ 2762 Going from 谁借莪1个温暖的怀抱¢/ 2021年12月20日 16:11/ 0 赞/ 311 阅读
相关 拓扑排序 一个较大的工程往往被划分成许多子工程,我们把这些子工程称作活动(activity)。在整个工程中,有些子工程(活动)必须在其它有关子工程完成之后才能开始,也就是说,一个子工程 野性酷女/ 2021年09月19日 05:04/ 0 赞/ 483 阅读
还没有评论,来说两句吧...