鏈式前向星

2022-08-09 04:12:14 字數 465 閱讀 2801

鏈式前向星實質為陣列模擬鍊錶。

不妨設有n個頂點,m條邊,首先為每條邊編號為0~m-1.

對每個頂點的一條邊定義乙個三元陣列(to,w,next)。其中to為該邊的終點,w為該邊的權值,next為以該頂點出發的另一條邊的編號,那如何從頂點找到對應邊的編號呢,這時就引入了head陣列,head為以該頂點出發的最後一條邊的編號。

void  add_edge(int u, int v, int w)//

u為起點,v為終點,w為權值

遍歷時只需要從每乙個頂點出發(for從1~n)

再從每乙個頂點的head[i]出發搜尋出以該頂點出發的所有邊。

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

}

至於初始問題,因為邊的編號為0~m-1,所以初始值就不能為0,所以-1;

如果邊的編號從1開始,初始值則可以改動。

前向星和鏈式前向星

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

前向星和鏈式前向星

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

前向星和鏈式前向星

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