下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第Python經(jīng)典貪心算法之Prim算法案例詳解最小生成樹的Prim算法也是貪心算法的一大經(jīng)典應(yīng)用。Prim算法的特點(diǎn)是時(shí)刻維護(hù)一棵樹,算法不斷加邊,加的過程始終是一棵樹。
Prim算法過程:
一條邊一條邊地加,維護(hù)一棵樹。
初始E={}空集合,V={任選的一個(gè)起始節(jié)點(diǎn)}
循環(huán)(n–1)次,每次選擇一條邊(v1,v2),滿足:v1屬于V,v2不屬于V。且(v1,v2)權(quán)值最小。
E=E+(v1,v2)
V=V+v2
最終E中的邊是一棵最小生成樹,V包含了全部節(jié)點(diǎn)。
以下圖為例介紹Prim算法的執(zhí)行過程。
Prim算法的過程從A開始V={A},E={}
選中邊AF,V={A,F},E={(A,F)}
選中邊FB,V={A,F,B},E={(A,F),(F,B)}
選中邊BD,V={A,B,F,D},E={(A,F),(F,B),(B,D)}
選中邊DE,V={A,B,F,D,E},E={(A,F),(F,B),(B,D),(D,E)}
選中邊BC,V={A,B,F,D,E,c},E={(A,F),(F,B),(B,D),(D,E),(B,C)},算法結(jié)束。
Prim算法的證明:假設(shè)Prim算法得到一棵樹P,有一棵最小生成樹T。假設(shè)P和T不同,我們假設(shè)Prim算法進(jìn)行到第(K–1)步時(shí)選擇的邊都在T中,這時(shí)Prim算法的樹是P',第K步時(shí),Prim算法選擇了一條邊e=(u,v)不在T中。假設(shè)u在P'中,而v不在。
因?yàn)門是樹,所以T中必然有一條u到v的路徑,我們考慮這條路徑上第一個(gè)點(diǎn)u在P'中,最后一個(gè)點(diǎn)v不在P'中,則路徑上一定有一條邊f(xié)=(x,y),x在P'中,而且y不在P'中。
我們考慮f和e的邊權(quán)w(f)與w(e)的關(guān)系:若w(f)w(e),在T中用e換掉f(T中加上e去掉f),得到一個(gè)權(quán)值和更小的生成樹,與T是最小生成樹矛盾。
若w(f)w(e),Prim算法在第K步時(shí)應(yīng)該考慮加邊f(xié),而不是e,矛盾。
因此只有w(f)=w(e),我們在T中用e換掉f,這樣Prim算法在前K步選擇的邊在T中了,有限步之后把T變成P,而樹權(quán)值和不變,從而Prim算法是正確的。
請仔細(xì)理解Prim算法——時(shí)刻維護(hù)一棵生成樹。我們的證明構(gòu)造性地證明了所有地最小生成樹地邊權(quán)(多重)集合都相同!
N個(gè)點(diǎn)M條邊的無向連通圖,每條邊有一個(gè)權(quán)值,求該圖的最小生成樹。
最后,我們來提供輸入輸出數(shù)據(jù),由你來寫一段程序,實(shí)現(xiàn)這個(gè)算法,只有寫出了正確的程序,才能繼續(xù)后面的課程。
第1行:2個(gè)數(shù)N,M中間用空格分隔,N為點(diǎn)的數(shù)量,M為邊的數(shù)量。(2=N=1000,1=M=50000)
第2-M+1行:每行3個(gè)數(shù)SEW,分別表示M條邊的2個(gè)頂點(diǎn)及權(quán)值。(1=S,E=N,1=W=10000)
輸出最小生成樹的所有邊的權(quán)值之和。
914
124
238
347
459
5610
672
781
897
2811
392
796
364
4614
188
輸出示例
37
maxv=10001
n,m=list(map(int,input().split()))
V=set([1])
cost=[]
foriinrange(n+1):
a=[]
forjinrange(n+1):
a.append(maxv)
cost.append(a)
foriinrange(m):
s,e,w=list(map(int,input().split()))
cost[s][e]=w
cost[e][s]=w
closet=[0]
lowcost=[maxv]
foriinrange(1,n+1):
closet.append(1)
lowcost.append(cost[1][i])
ans=0
foriinrange(n-1):
forjinrange(2,n+1):
if(lowcost[j]!=0)and(lowcost[j]lowcost[k]):k=j
forjinrange(2,n+1):
ifco
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 口腔科處方審核課件
- 口腔種植知識(shí)點(diǎn)
- 口腔檢查流程話術(shù)培訓(xùn)
- 制氫制氮安全培訓(xùn)課件教學(xué)
- 臺(tái)風(fēng)防御應(yīng)急技能培訓(xùn)
- 制作培訓(xùn)高級班
- 2026年陜西省寶雞市高三高考模擬檢測試題(一)語文試題及答案
- 口才掩耳盜鈴課件
- 制作培訓(xùn)會(huì)新聞稿
- 臍帶護(hù)理的睡眠姿勢建議
- 安全生產(chǎn)目標(biāo)及考核制度
- (2026版)患者十大安全目標(biāo)(2篇)
- 2026年北大拉丁語標(biāo)準(zhǔn)考試試題
- 臨床護(hù)理操作流程禮儀規(guī)范
- 2025年酒店總經(jīng)理年度工作總結(jié)暨戰(zhàn)略規(guī)劃
- 空氣栓塞課件教學(xué)
- 2025年國家市場監(jiān)管總局公開遴選公務(wù)員面試題及答案
- 肌骨康復(fù)腰椎課件
- 患者身份識(shí)別管理標(biāo)準(zhǔn)
- 2025年10月自考04184線性代數(shù)經(jīng)管類試題及答案含評分參考
- 2025年勞動(dòng)保障協(xié)理員三級技能試題及答案
評論
0/150
提交評論