




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、済 int Prim( int graph MAX, int n) /* lowcosti 記錄以 i 為終點(diǎn)的邊的最小權(quán)值,當(dāng) lowcosti=0 時(shí)表示終點(diǎn) i 加入生成樹 */ int lowcost MAX; /* msti 記錄對(duì)應(yīng) lowcosti 的起點(diǎn),當(dāng) msti=0 時(shí)表示起點(diǎn) i 加入生成樹 */ int mst MAX; int i, j, min, minid, sum = 0; /* 默認(rèn)選擇 1號(hào)節(jié)點(diǎn)加入生成樹,從 2號(hào)節(jié)點(diǎn)開始初始化 */ for (i = 2; i = n; i+) /* 最短距離初始化為其他節(jié)點(diǎn)到 1號(hào)節(jié)點(diǎn)的距離 */ lowcosti =
2、 graph1i; /* 標(biāo)記所有節(jié)點(diǎn)的起點(diǎn)皆為默認(rèn)的 1號(hào)節(jié)點(diǎn) */ msti = 1; /* 標(biāo)記 1號(hào)節(jié)點(diǎn)加入生成樹 */ mst1 = 0; /* n 個(gè)節(jié)點(diǎn)至少需要 n-1 條邊構(gòu)成最小生成樹 */ for (i = 2; i = n; i+) min = MAXCOS; T minid = 0; /* 找滿足條件的最小權(quán)值邊的節(jié)點(diǎn) minid */ for (j = 2; j =n; j+) /* 邊權(quán)值較小且不在生成樹中 */ if (lowcostj min minid = j; /* 輸出生成樹邊的信息 : 起點(diǎn),終點(diǎn),權(quán)值 */ printf( %c - %c : %dn
3、, mstminid +A - 1, minid + A - 1, min); /* 累加權(quán)值 */ sum += min; /* 標(biāo)記節(jié)點(diǎn) minid 加入生成樹 */ lowcostminid = 0; /* 更新當(dāng)前節(jié)點(diǎn) minid 到其他節(jié)點(diǎn)的權(quán)值 */ for (j = 2; j =n; j+) /* 發(fā)現(xiàn)更小的權(quán)值 */ if ( graph minidj lowcostj) /* 更新權(quán)值信息 */ lowcostj = graph minidj; /* 更新最小權(quán)值邊的起點(diǎn) */ mstj = minid; /* 返回最小權(quán)值和 */ return sum; int main(
4、) printf( 請(qǐng)輸入點(diǎn)數(shù)和邊數(shù): ); int i, j, k, m, n; int x, y, cost; char chx, chy; scanf( %d%d, /* 讀取節(jié)點(diǎn)和邊的數(shù)目 */ getchar(); printf( 請(qǐng)輸入邊的信息: ); /* 初始化圖,所有節(jié)點(diǎn)間距離為無(wú)窮大 */ for (i = 1; i = m; i+) for (j = 1; j = m; j+) graphij =MAXCOS; T /* 讀取邊信息 */ for (k = 0; k n; k+) scanf( %c %c %d, getchar(); i = chx - A + 1; j
5、 = chy - A + 1; graphij = cost; graphji = cost; /* 求解最小生成樹 */ cost = Prim(graph, m); /* 輸出最小權(quán)值和 */ printf( Total:%dn , cost); /system(pause); return 0; 代碼說(shuō)明: 1、2個(gè)for循環(huán)都是從2開始的,因?yàn)橐话阄覀兡J(rèn)開始就把第一個(gè)節(jié)點(diǎn)加入生成 樹,因此之后不需要再次尋找它。 2、lowcosti記錄的是以節(jié)點(diǎn)i為終點(diǎn)的最小邊權(quán)值。初始化時(shí)因?yàn)槟J(rèn)把第一個(gè)節(jié) 點(diǎn)加入生成樹,因此 lowcosti = graph1i ,即最小邊權(quán)值就是各節(jié)點(diǎn)到 1
6、號(hào)節(jié)點(diǎn) 的邊權(quán)值。 3、msti記錄的是lowcosti對(duì)應(yīng)的起點(diǎn),這樣有起點(diǎn),有終點(diǎn),即可唯一確定一條 邊了。初始化時(shí) msti = 1,即每條邊都是從 1 號(hào)節(jié)點(diǎn)出發(fā)。 編寫程序 :對(duì)于如下一個(gè)帶權(quán)無(wú)向圖,給出節(jié)點(diǎn)個(gè)數(shù)以及所有邊權(quán)值,用 Prim 算法 求最小生成樹。 三、結(jié)論 1 、實(shí)驗(yàn)結(jié)果 輸入數(shù)據(jù): 7 11 A B 7 A D 5 B C 8 B D 9 B E 7 C E 5 D E 15 D F 6 E F 8 F G 11 輸出: A - D : 5 D - F : 6 A - B : 7 B - E : 7 E - C : 5 E - G : 9 Total:39 實(shí)驗(yàn)結(jié)果
7、如圖: 02109 I I I I I IGGFFEEEDCD GCEBFD1986157985 J 15曠嚴(yán) 9 57 7 6 5氐洽 C:w5-dow$sy$-em32cmd.exe GGFFEEEDCD竦 1986157985 15曠 A C:w5-dcsy$-em32cmd.exe X 2、分析討論 Prim算法的基本思想如下: 首先從V中任取一個(gè)頂點(diǎn)(假定取v1),將生成樹T置為僅有一 個(gè)結(jié)點(diǎn)v1的樹,即U=v1;然后只要U是V的真子集,就在所有那些一個(gè)端點(diǎn)在 T中,另一個(gè) 端點(diǎn)在T外的邊中,找一條最短(即權(quán)值最小 )的邊。假定符合條件的最短邊為 (vi,vj), 則把 該條邊和其不在 T中的頂點(diǎn)vj,分別并入T的邊集TE和頂點(diǎn)集U。如此進(jìn)行下去,每
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 供方采購(gòu)合同范本
- 企業(yè)項(xiàng)目合資合同范本
- 浙江長(zhǎng)興縣龍山中學(xué)人教版七年級(jí)下冊(cè)歷史與社會(huì)第八單元第三課 中華文明探源教學(xué)設(shè)計(jì)
- 2024年韶關(guān)市曲江區(qū)住房和城鄉(xiāng)建設(shè)管理局招聘筆試真題
- 公司英文合同范本
- 農(nóng)田路養(yǎng)護(hù)合同范本
- 前臺(tái)收銀合同范本
- 包材銷售合同范本
- 2024年金昌市金川區(qū)圖書館招聘筆試真題
- 農(nóng)村自建住宅買賣合同范本
- 醫(yī)院評(píng)審工作臨床科室資料盒目錄(15個(gè)盒子)
- 社區(qū)獲得性肺炎臨床路徑
- 壓力性損傷指南解讀
- 湯姆走丟了 詳細(xì)版課件
- 大學(xué)學(xué)院學(xué)生心理危機(jī)預(yù)防與干預(yù)工作預(yù)案
- 國(guó)有土地上房屋征收與補(bǔ)償條例 課件
- 安全文明施工管理(EHS)方案(24頁(yè))
- 水廠項(xiàng)目基于BIM技術(shù)全生命周期解決方案-城市智慧水務(wù)講座課件
- 幼兒園繪本:《閃閃的紅星》 紅色故事
- 鐵路建設(shè)項(xiàng)目施工企業(yè)信用評(píng)價(jià)辦法(鐵總建設(shè)〔2018〕124號(hào))
- 叉形件加工設(shè)計(jì)與分析論文
評(píng)論
0/150
提交評(píng)論