您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 管理学资料 > 7.5 有向无环图及应用
7.5有向无环图及应用7.5.1拓扑排序——用顶点边表示活动的网络,简称AOV网络(ActivityOnVertices)顶点:一个工程中的活动(Activity)边:活动的顶点间的优先关系(Relation)要解决的问题是:将各个顶点(代表各个活动)排列成一个线性有序的序列,使得AOV网络中所有应存在的前驱和后继关系都能得到满足。课程代号课程名先修课程C1高等数学C2程序设计基础C3离散数学C1,C2C4数据结构C3,C2C5高级语言程序设计C2C6编译方法C5,C4C7操作系统C4,C9C8普通物理C1C9计算机原理C8可以用有向图表示一个工程。在这种有向图中,用顶点表示活动。有向边Vi,Vj表示:Vi必须先于活动Vj进行。这种有向图叫做顶点表示活动的AOV网络(ActivityOnVertices)。在AOV网络中,如果活动Vi必须在活动Vj之前进行,则存在有向边Vi,Vj,AOV网络中不能出现有向回路,即有向环。在AOV网络中如果出现了有向环,则意味着某项活动应以自己作为先决条件。因此,对给定的AOV网络,必须先判断它是否存在有向环。一、什么是拓扑排序将各个顶点(代表各个活动)排列成一个线性有序的序列,使得AOV网络中所有应存在的前驱和后继关系都能得到满足。这种构造AOV网络全部顶点的拓扑有序序列的运算就叫做拓扑排序。例如,对学生选课工程图进行拓扑排序,得到的拓扑有序序列为C1,C2,C3,C4,C5,C6,C8,C9,C7或C1,C8,C9,C2,C5,C3,C4,C7,C6例如,对学生选课工程图进行拓扑排序,得到的拓扑有序序列为C1,C2,C3,C4,C5,C6,C8,C9,C7或C1,C8,C9,C2,C5,C3,C4,C7,C6二、进行拓扑排序的方法首先建立(n个顶点的)AOV网。(1)在AOV网络中选一个没有直接前驱的顶点(入度为0的顶点),并输出之;(2)从图中删去该顶点,同时删去所有它发出的边;重复(1)和(2),直到全部顶点均已输出,拓扑有序序列形成,拓扑排序完成;若图中还有未输出的顶点,但已跳出处理循环。这说明图中存在环。v1v5v4v3v6三、拓扑排序的过程有向无环图v2v1v5v4v3v6v2(1)输出顶点v6(2)输出顶点v1(3)输出顶点v3(4)输出顶点v4(5)输出顶点v2(6)输出顶点v5v1v5v4v3v6三、拓扑排序的过程有向无环图v2v1v5v4v3v6v2(1)输出顶点v6(2)输出顶点v1(3)输出顶点v3(4)输出顶点v4(5)输出顶点v2(6)输出顶点v5四、存储结构(邻接表)v1v2v3v4v5v612345602123043552054idvexfirstdataarcv1v5v4v3v6v22adjvexnextarctypedefstructarcnode{intadjvex;arcnode*nextarc;}*pointer;//表结点structnode{charvexdata;intid;//顶点的入度pointerfirstarc;}dig[100];//一组头结点在邻接表的头结点中增设了一个数据项id,记录该顶点的入度。入度为零的顶点即无前驱的顶点。在拓扑排序算法中,使用一个存放入度为零的顶点的链式栈,供选择和输出无前驱的顶点。只要出现入度为零的顶点,就将它加入栈中。五、拓扑排序算法思想:(1)建立入度为零的顶点栈;(2)当入度为零的顶点栈不空时,重复执行:(2)-1从顶点栈中退出一个顶点,并输出之;(2)-2从AOV网络中删去这个顶点和它发出的边,边的终顶点入度减一;(2)-3如果边的终顶点入度减至0,则该顶点进入度为零的顶点栈;(3)如果输出顶点个数少于AOV网络的顶点个数,则报告网络中存在有向环。将顶点i进栈时,执行以下指针的修改:dig[i].id=top;top=i;//top指向新栈顶i,原栈顶元素放在id[i]中退栈操作可以写成:j=top;top=dig[top].id;//位于栈顶的顶点的位置记于j,top退到次栈顶六、拓扑排序的算法voidtoposort(){inistack(s);//置空栈for(i=1;i=n;++i)if(dig[i].id==0)push(s.i);//入度为零的顶点栈count=0;//count为计数器,计输出顶点数while(!stackempty(s)){j=pop(s);printf(dig[j].vexdata);count++;q=dig[j].firstarc;//q指示以vj为尾的第一条弧结点while(q){k=q-adjvex;//顶点vk为vj的直接后继dig[k].id--;if(dig[k].id==0)push(s,k);//新的入度为零的顶点入栈q=q-nextarc;}}if(countn)error(“该图中存在回路”)}分析此拓扑排序算法可知,如果AOV网络有n个顶点,e条边,在拓扑排序的过程中,搜索入度为零的顶点,建立链式栈所需要的时间是O(n)。在正常的情况下,有向图有n个顶点,每个顶点进一次栈,出一次栈,共输出n次。顶点入度减一的运算共执行了e次。所以总的时间复杂度为O(n+e)。7.5.2关键路径——用边表示活动的网络,简称AOE网络(ActivityOnEdges)边:一个工程中的活动(Activity)边上权值:活动持续时间(Duration)顶点:事件(Event)要解决的问题是:(1)完成整个工程至少需要多少时间(假设网络中没有环)?(2)为缩短完成工程所需的时间,应当加快哪些活动?完成整个工程所需的时间取决于从源点到汇点的最长路径长度,即在这条路径上所有活动的持续时间之和。这条路径长度最长的路径就叫做关键路径(CriticalPath)。定义几个与计算关键活动有关的量:(1)事件Vj的最早可能开始时间Ve(j)——从源点V1到顶点Vj的最长路径长度。(2)事件Vi的最迟允许开始时间Vl[i]——在保证汇点Vn在Ve[n]时刻完成的前提下,事件Vi的允许的最迟开始时间。Ve(1)=0Ve(j)=max{Ve(i)+i,j的权}Vl(n)=Ve(n)Vl(i)=min{Vl(j)-i,j的权}1324a1=8a2=65678a10=12a9=6a8=18a5=26a6=4a7=6a3=14a4=10VeVl12345678086222832465808142228404658关键路径:124578
本文标题:7.5 有向无环图及应用
链接地址:https://www.777doc.com/doc-3881292 .html