NYOJ佈線問題

2021-06-19 03:35:34 字數 1099 閱讀 3196

描述

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

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

樣例輸出

這是典型的最小生成樹。書上用的是鄰接表做的,但是我沒有實現。看了一下別人的,用鄰接矩陣實現,還可以。用乙個二維陣列儲存這個圖,在用乙個 bool 陣列表示這個頂點是否已經訪問過。用乙個陣列儲存某個未訪問過的頂點到生成樹的距離,然後每次取這個陣列中最小的值。

#include#include#define n 501

#define infinity 1000000

int map[ n ][ n ];

bool vis[ n ];

int lowcost[ n ];//儲存每個沒有訪問過的頂點與生成樹相連的權值

int prim( int ,int );

int main()

{ int t;

scanf("%d",&t);

while( t-- )

{memset( map, 0, sizeof( map ) );

memset( vis, 0, sizeof( vis ) );

int m,n,sum1;

scanf("%d%d",&m,&n);

int i,j,a,b,c;

for( i=0; i

nyoj 38 佈線問題

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

佈線問題 nyoj38

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

NYOJ 38 佈線問題

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