筆記 前向星

2021-08-01 14:53:30 字數 1381 閱讀 5748

前向星與鄰接表都儲存圖的方式

前向星是一種資料結構,以儲存邊的方式來儲存圖。構造方法如下:讀入每條邊的資訊,將邊存放在陣列中,把陣列中的邊按照起點順序排序(可以使用基數排序,如下面例程),前向星就構造完了。通常用在點的數目太多,或兩點之間有多條弧的時候。一般在別的資料結構不能使用的時候才考慮用前向星。除了不能直接用起點終點定位以外,前向星幾乎是完美的。

/*

樣例:6 8

1 2 1

1 3 1

1 6 1

2 4 1

3 4 1

3 5 1

4 6 1

5 6 1

*/#include

#include

#include

#include

#include

#include

#define m 1000

#define n 1000

using

namespace

std;

int n,m;int num=0;//num是邊的編號

int b[m],w[m],nt[m],p[n],flag[n];//n是最大頂點數,m是最大邊數

/*b[i]=j表示編號為i的邊 到達的點為j

w[i]=j表示編號為i的邊 的權值為j

nt[i]=j表示編號為i的邊 的前乙個邊為j

p[i]=j 表示頂點p指向的邊 的編號為j

*/void insert()

}void dfs(int x)

} int main()

同鄰接表的廣搜

前向星的廣搜遍歷

/*

樣例:6 8

1 2 1

1 3 1

1 6 1

2 4 1

3 4 1

3 5 1

4 6 1

5 6 1

*/#include

#include

#include

#include

#include

#include

#include

#define m 1000

#define n 1000

using

namespace

std;

int n,m;int num=0;//num是邊的編號

int b[m],w[m],nt[m],p[n],flag[n];

queue

q;void insert()

}void bfs(int x)

前向星和鏈式前向星

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

前向星和鏈式前向星

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

前向星和鏈式前向星

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