nyoj 38 佈線問題(最小生成樹)

2021-07-30 09:44:28 字數 1004 閱讀 6699

時間限制:

1000 ms  |  記憶體限制:

65535 kb

難度:4 描述

南陽理工學院要進行用電線路改造,現在校長要求設計師設計出一種佈線方式,該佈線方式需要滿足以下條件:

1、把所有的樓都供上電。

2、所用電線花費最少

輸入第一行是乙個整數n表示有n組測試資料。(n<5)

每組測試資料的第一行是兩個整數v,e.

v表示學校裡樓的總個數(v<=500)

隨後的e行裡,每行有三個整數a,b,c表示a與b之間如果建鋪設線路花費為c(c<=100)。(哪兩棟樓間如果沒有指明花費,則表示這兩棟樓直接連通需要費用太大或者不可能連通)

隨後的1行裡,有v個整數,其中第i個數表示從第i號樓接線到外界供電設施所需要的費用。( 0

輸出每組測試資料輸出乙個正整數,表示鋪設滿足校長要求的線路的最小花費。

樣例輸入

1

4 61 2 10

2 3 10

3 1 10

1 4 1

2 4 1

3 4 1

1 3 5 6

樣例輸出

4

#include#include#includeusing namespace std;

int v,e,msum=1000;

int per[505];

struct edgeeg[124755];

bool cmp(edge e1,edge e2)

int find(int r)

void join(int r1,int r2)

int main()

for(int i=0;isort(eg,eg+e,cmp);

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

for(int i=0;i} printf("%d\n",msum);

} return 0;

}

NYOJ 38 佈線問題 最小生成樹

時間限制 1000 ms 記憶體限制 65535 kb 難度 4 描述 南陽理工學院要進行用電線路改造,現在校長要求設計師設計出一種佈線方式,該佈線方式需要滿足以下條件 1 把所有的樓都供上電。2 所用電線花費最少 輸入第一行是乙個整數n表示有n組測試資料。n 5 每組測試資料的第一行是兩個整數v,...

NYOJ 38 最小生成樹

原來是求二維陣列的每行或者每列的最小值,不過需要主要的是如果是4個點,只需要3條邊就可以完全連線起來了,所以只需要找3次就行了。4條邊有一條邊會重複,需要捨棄。就用題目的測試資料比較,用二維陣列儲存點與點連線的距離。就用i代表行,j代表列。會發現 i,j都是從第二行開始的。而且跟y x 直線對稱。為...

nyoj 38 佈線問題

nyoj 38 佈線問題 時間限制 1000 ms 記憶體限制 65535 kb難度 4 描述 南陽理工學院要進行用電線路改造,現在校長要求設計師設計出一種佈線方式,該佈線方式需要滿足以下條件 1 把所有的樓都供上電。2 所用電線花費最少 輸入第一行是乙個整數n表示有n組測試資料。n 5 每組測試資...