鏈式前向星 問題式引導

2021-10-10 10:28:42 字數 959 閱讀 6584

用邊作為儲存核心

struct edge

edge[maxn]

;int head[maxn]

;

問題一:邊的另乙個節點在哪?

與鄰接矩陣儲存邏輯很像,有乙個「頭」,用head裡的下標表示。

問題二:怎麼去模擬鄰接矩陣的頭後接乙個乙個的節點?

void

addedge

(int from,

int to,

int w)

問題三:怎麼遍歷?
​	   memset

(head,-1

,sizeof

(head));

//遍歷所有頂點

for(

int i =

1; i <= v; i++

)}

四、完整**
#include

#include

#include

using

namespace std;

const

int maxn =

1005

;struct edge

edge[maxn]

;int v, e, cnt, head[maxn];

void

inti()

void

addedge

(int from,

int to,

int w)

intmain()

for(

int i =

1; i <= v; i++)}

​ return0;

}

輸出情況:

前向星和鏈式前向星

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

前向星和鏈式前向星

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

前向星和鏈式前向星

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