拓撲排序(鏈式前向星 佇列實現)

2021-08-10 09:53:03 字數 756 閱讀 4821

拓撲排序:對於有向無環圖的排序,對於乙個有向無環圖來說,拓撲排序就是講該圖中的所有定點排成乙個線性順序。使得途中任意一對定點u和v,若存在邊關係,u在v之前。

實現思路:

1:從圖中選擇乙個入度為0的頂點,並輸出他

2:從圖中刪除該點,並且刪除該定點出發的所有有向邊

3:重複上述兩步

**如下:

#includeusing namespace std;

const int n = 100005;

const int m = 100005;

struct edgenode;

edgenode edge[n];

int head[m];

int n,m;

int indegree[n];

void toposort()

} for(int i = 0 ; i < iq ; i++)

} }for(int i = 0 ; i < iq; i ++)

cout << queue[i] << " ";

cout << endl;

}int main()

// for(int i = 1; i <= n ; i++)

// }

toposort();

return 0 ;

} /*

5 55 4

1 2

2 3

1 3

1 5*/

前向星和鏈式前向星

我們首先來看一下什麼是前向星.前向星是一種特殊的邊集陣列,我們把邊集陣列中的每一條邊按照起點從小到大排序,如果起點相同就按照終點從小到大排序,並記錄下以某個點為起點的所有邊在陣列中的起始位置和儲存長度,那麼前向星就構造好了.用len i 來記錄所有以i為起點的邊在陣列中的儲存長度.用head i 記...

前向星和鏈式前向星

前向星 前向星是一種特殊的邊集陣列,我們把邊集陣列中的每一條邊按照起點從小到大排序,如果起點相同就按照終點從小到大排序,並記錄下以某個點為起點的所有邊在陣列中的起始位置。鏈式前向星 鏈式前向星其實就是靜態建立的鄰接表,時間效率為o m 空間效率也為o m 遍歷效率也為o m next表示當前結點的下...

前向星和鏈式前向星

1 前向星 前向星是以儲存邊的方式來儲存圖,先將邊讀入並儲存在連續的陣列中,然後按照邊的起點進行排序,這樣陣列中起點相等的邊就能夠在陣列中進行連續訪問了。它的優點是實現簡單,容易理解,缺點是需要在所有邊都讀入完畢的情況下對所有邊進行一次排序,帶來了時間開銷,實用性也較差,只適合離線演算法。圖一 2 ...