鏈式前向星

2021-09-26 10:56:39 字數 1127 閱讀 6132

鏈式前向星是鄰接矩陣的一種。

如何用鏈式前向星來存圖?

將上圖存存完後應該是這個樣子…

v表示頂點,len表示長度,eid 代表這條邊的編號,next表示指向下一條邊的編號

左邊陣列p[u]表示,以u 為起點 所指的第一條的邊的編號

比如1號點和2號點之間有一條邊長度為10,還和3號點有一條邊長度為5

所以點集可以用陣列表示,邊集可以用結構體表示

const int max_n = 100;

const int max_m = 10000;

struct nodee[max_m];

int p[max_n],eid;

next 是指向下一條邊的編號。

構圖之前要初始化,頂點之間開始沒有邊,記為-1,每進入一條邊用頭插的方式。

編號一開始初始化為0。

void init()

用頭插的方式加邊

怎麼給每條邊編號呢?eid代表編號,初始化為0,每當加入一條邊的時候eid++.

void insert(int u,int v,int len)

很明顯可以根據每個點,遍歷它所有的邊,當next為-1時,說明遍歷完全

int main()

cout《列印的結果和預期一樣

當加入第一條邊時 , p[1] = 0

當加入第二條邊時

此時p[1] 值為1 e[eid].next值為0

然後整個過程都很好理解

#include #include #include using namespace std;

const int max_n = 100;

const int max_m = 10000;

struct nodee[max_m];

int p[max_n],eid;

void init()

void insert(int u,int v,int len)

int main()

cout<} cout << p[1]

}

前向星和鏈式前向星

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

前向星和鏈式前向星

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

前向星和鏈式前向星

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