簡單理解鏈式前向星

2021-09-09 08:46:21 字數 805 閱讀 7498

前向星是一種特殊的邊集陣列,我們把邊集陣列中的每一條邊按照起點從小到大排序,如果起點相同就按照終點從小到大排序,

並記錄下以某個點為起點的所有邊在陣列中的起始位置和儲存長度,那麼前向星就構造好了.

初始位置u[i],終止位置v[i],權w[i]。

first[i]初始值全為-1。

first[i],它是用來表示以i為起點的第一條邊儲存的位置,實際上你會發現這裡的第一條邊儲存的位置其實

在以i為起點的所有邊的最後輸入的那個編號.

next[i],陣列存編號為i的邊的上一條邊的編號,如果這個邊是以u[i]為頂點的第一條邊,則next[i]為-1。

下面為**:

#include #include #include #define inf 0x3f3f3f3f

using namespace std;

int main()

for(int i=1;i<=m;i++)

for(int i=1;i<=m;i++) //遍歷 }

return 0;

}/* 9 5

1 4 9

4 3 8

1 2 5

2 4 6

1 3 7 */

理解鏈式前向星

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

深度理解鏈式前向星

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

深度理解鏈式前向星

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