鏈式前向星存邊

2021-08-31 21:03:55 字數 706 閱讀 9937

這邊文章是基於網上流傳最廣的改編,改了點內容方便更好的理解。

我們輸入邊的順序為:

1 2,2 3,3 4,1 3,4 1,1 5,4 5

void add(int u,int v,int w)

按上圖模擬一下

add(1,2,w1)->edge[0].to = 2; edge[0].next = head[1]=-1;head[1]=0;

add(2,3,w2)->edge[1].to = 3; edge[1].next = head[2]=-1;head[2]=1;

add(3,4,w3)->edge[2].to = 4; edge[2].next = head[3]=-1;head[3]=2;

add(1,3,w4)->edge[3].to = 3; edge[3].next = head[1]=0; head[4]=3;

後面就不贅述了

edge[4].to = 1; edge[4].next = -1; head[4] = 4;

edge[5].to = 5; edge[5].next = 3; head[1] = 5;

edge[6].to = 5; edge[6].next = 4; head[4] = 6;

前向星和鏈式前向星

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

前向星和鏈式前向星

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

前向星和鏈式前向星

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