有向無環圖:無環的有向圖,簡稱 DAG (Directed Acycline Graph) 圖。
一個有向圖的生成樹是一個有向樹,一個非連通有向圖的若干強連通分量生成若干有向樹,這些有向數形成生成森林。
在工程計划和管理方面的應用
除最簡單的情況之外,幾乎所有的工程都可分為若干個稱作“活動”的子工程,並且這些子工程之間通常受着一定條件的約束,例如:其中某些子工程必須在另一些子工
程完成之后才能開始。對整個工程和系統,人們關心的是兩方面的問題:
一是工程能否順利進行,即工程流程是否“合理”;
二是完成整個工程所必須的最短時間。
對應到有向圖即為進行拓撲排序(AOV網)和求關鍵路徑(AOE網)。
拓撲排序
AOV 網:用一個有向圖表示一個工程的各子工程及其相互制約的關系,其中以頂點表示活動,弧表示活動之間的優先制約關系,稱這種有向圖為頂點表示活動的網,簡稱AOV (Activity On Vertex network)網。
比如、某工程可分為7個子工程(V0、V1、V2、V3、V4、V5、V6),若用頂點表示子工程(也稱活動),用弧表示子工程間的順序關系,工程流程可用如下的AOV網表示。
比如排課表
AOV 網的特點:若從 i 到 j 有一條有向路徑,則 i是 j 的前驅;j 是 i 的后繼。若 < i , j > 是網中有向邊,則 i 是 j 的直接前驅; j 是 i 的直接后繼。AOV 網中不允許有回路,因為如果有回路存在,則表明某項活動以自己為先決條件,顯然這是荒謬的。
問題:如何判別 AOV 網中是否存在回路?即如何AOV網表示的工程能順利進行?合理?
拓撲排序:
在 AOV 網沒有回路的前提下,我們將全部活動排列成一個線性序,使得若 AOV 網中有弧 <i, j> 存在,則在這個序列中, i 一定排在 j的前面,具有這種性質的線性序列稱為拓撲有序序列,相應的拓撲有序排序的算法稱為拓撲排序。
注意:
檢測 AOV 網中是否存在環方法:


3)重復1)、2),直接全部輸出全部頂點或有向圖中不存在無前趨的結點時為止。
刪除 v2,v3,v4,v5,v6以及以他們為尾部的弧
注意:一個AOV網的拓撲序列不是唯一的
歡迎關注
dashuai的博客是終身學習踐行者,大廠程序員,且專注於工作經驗、學習筆記的分享和日常吐槽,包括但不限於互聯網行業,附帶分享一些PDF電子書,資料,幫忙內推,歡迎拍磚!