普利姆算法

//無(wú)向圖

//默認(rèn)從V0開始

#include<iostream>

#include<stack>

#include<queue>

using namespace std;

const int INF=999;//最大值怎么取啊反砌?

//這里是這個(gè)代碼里面設(shè)置的無(wú)窮大

const int Maxsize=10;

int visited[Maxsize];

struct Edge//這個(gè)結(jié)構(gòu)體用于記錄最短邊的相關(guān)信息

{

? ? int adjvex;//候選最短邊的鄰接點(diǎn)

? ? int lowcost;//候選最短邊的權(quán)值

}shortEdge[Maxsize];//記錄最短邊的數(shù)組

class MGraph

{

? ? public:

? ? MGraph(int a[],int n,int e);//n個(gè)頂點(diǎn)赢织,e條邊

? ? ~MGraph() {}

? ? int Prim(MGraph G);//普利姆算法

? ? private:

? ? int vertex[Maxsize];//存放圖中頂點(diǎn)的數(shù)組

? ? int arc[Maxsize][Maxsize];//存放圖中邊的數(shù)組

? ? int vertexNum,arcNum;//圖的頂點(diǎn)數(shù)和邊數(shù)

};

MGraph::MGraph(int a[],int n,int e)//構(gòu)造函數(shù)

{

? ? vertexNum=n;

? ? arcNum=e;

? ? int weight;

? ? for(int i=0;i<vertexNum;i++)

? ? {

? ? ? ? ? vertex[i]=a[i];//頂點(diǎn)信息錄入

? ? }

? ? for(int i=0;i<vertexNum;i++)

? ? {

? ? ? ? ? for(int j=0;j<vertexNum;j++)//將各條邊進(jìn)行初始化

? ? ? ? ? {

? ? ? ? ? ? ? if(i==j)

? ? ? ? ? ? ? {

? ? ? ? ? ? ? ? ? ? arc[i][j]=0;//一個(gè)點(diǎn)

? ? ? ? ? ? ? }

? ? ? ? ? ? ? else arc[i][j]=INF;//不相鄰設(shè)置為無(wú)窮大

? ? ? ? ? }

? ? }

? ? cout<<"請(qǐng)分別輸入無(wú)向圖的邊對(duì)應(yīng)的點(diǎn)及其權(quán)值"<<endl;

? ? for(int k=0;k<arcNum;k++)

? ? {//依據(jù)設(shè)置的邊數(shù),將其頂點(diǎn)錄入缀磕,在這里設(shè)置為無(wú)向圖

? ? ? ? ? int i,j;

? ? ? ? ? cin>>i>>j; //輸入該邊依附的兩個(gè)頂點(diǎn)的編號(hào)

? ? ? ? ? cin>>weight;//錄入權(quán)值

? ? ? ? ? arc[i][j]=weight;

? ? ? ? ? arc[j][i]=weight;

? ? }

? ? cout<<"以下輸出鄰接矩陣:"<<endl;

? ? for(int i=0;i<vertexNum;i++)//輸出鄰接矩陣啊

? ? {

? ? ? ? ? for(int j=0;j<vertexNum;j++)

? ? ? ? ? {

? ? ? ? ? ? ? if(arc[i][j]==INF)

? ? ? ? ? ? ? {

? ? ? ? ? ? ? ? ? ? cout<<"∞\t";

? ? ? ? ? ? ? }

? ? ? ? ? ? ? else

? ? ? ? ? ? ? {

? ? ? ? ? ? ? ? ? ? cout<<arc[i][j]<<'\t';

? ? ? ? ? ? ? }

? ? ? ? ? }

? ? ? ? ? cout<<endl;

? ? }

}

//k=MinEdk=MinEdge(shortEdge,G.vertexNum);//調(diào)用函數(shù)找最短邊的鄰接點(diǎn)編號(hào)

int MinEdge(struct Edge shortEdge[],int n)//記錄最短邊的數(shù)組,圖的頂點(diǎn)數(shù)

{

? ? //int min=INF,minbd=0;

? ? int minarcver=0;

? ? int min=INF;

? ? for(int i=0;i<n;i++)

? ? {

? ? ? ? ? //if((shortEdge[i].lowcost<min)&&(shortEdge[i].lowcost!=0))

? ? ? ? ? if((shortEdge[i].lowcost<min)&&(shortEdge[i].lowcost!=0))//有邊且。劣光。袜蚕。

? ? ? ? ? {

? ? ? ? ? ? ? minarcver=i;//記錄候選最短邊的頂點(diǎn)編號(hào)

? ? ? ? ? ? ? min=shortEdge[i].lowcost;//記錄這一輪的最短邊

? ? ? ? ? }

? ? }

? ? return minarcver;//返回該頂點(diǎn)編號(hào)

}

int MGraph::Prim(MGraph G)//默認(rèn)從v0開始

{

? ? int k=0,j=0;

? ? int sum=0;

? ? //原來(lái)是默認(rèn)這個(gè)最小生成樹的其實(shí)點(diǎn)從第一個(gè)頂點(diǎn)開始

? ? //以下初始化輔助數(shù)組shortEdge

? ? for(int i=1;i<G.vertexNum;i++)

? ? {

? ? ? ? ? shortEdge[i].lowcost=G.arc[0][i];

? ? ? ? ? shortEdge[i].adjvex=0;//此時(shí)的鄰接點(diǎn)是v0

? ? }

? ? shortEdge[0].lowcost=0;//將頂點(diǎn)0加入集合U

? ? for(int i=1;i<G.vertexNum;i++)//遍歷v0之外的所有頂點(diǎn)

? ? {

? ? ? ? ? k=MinEdge(shortEdge,G.vertexNum);//調(diào)用函數(shù)找最短邊的鄰接點(diǎn)編號(hào)

? ? ? ? ? cout<<"找到的權(quán)值小的邊及其所對(duì)應(yīng)的權(quán)值:";

? ? ? ? ? cout<<"V"<<shortEdge[k].adjvex<<"->V"<<k<<"="<<shortEdge[k].lowcost<<endl;

? ? ? ? ? sum+=shortEdge[k].lowcost;//累積最小權(quán)值

? ? ? ? ? shortEdge[k].lowcost=0;//將頂點(diǎn)k加入集合U中

? ? ? ? ? for(j=1;j<G.vertexNum;j++)//調(diào)整數(shù)組shortEdge[n]

? ? ? ? ? {

? ? ? ? ? ? ? if(G.arc[k][j]<shortEdge[j].lowcost)

? ? ? ? ? ? ? {

? ? ? ? ? ? ? ? ? ? shortEdge[j].lowcost=G.arc[k][j];

? ? ? ? ? ? ? ? ? ? shortEdge[j].adjvex=k;

? ? ? ? ? ? ? }

? ? ? ? ? }

? ? }

? ? return sum;

}

int main()

{

? ? int n,e;

? ? int a[Maxsize];

? ? cout<<"請(qǐng)輸入頂點(diǎn)數(shù)和邊數(shù):"<<endl;

? ? cin>>n>>e;//n個(gè)頂點(diǎn),e條邊

? ? cout<<"請(qǐng)依次輸入各個(gè)頂點(diǎn)信息:"<<endl;

? ? for(int i=0;i<n;i++)

? ? {

? ? ? ? ? cin>>a[i];

? ? ? ? ? //visited[i]=0;//

? ? }

? ? MGraph MG(a,n,e);//構(gòu)造函數(shù)

? ? cout<<"最小生成樹權(quán)值總和為:"<<MG.Prim(MG)<<endl;

? ? return 0;

}

//測(cè)試樣例

//6 9

//0 1 34

//0 2 46

//0 5 19

//1 4 12

//4 5 26

//2 5 25

//2 3 17

//3 5 25

//3 4 38

//

//結(jié)果99

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末绢涡,一起剝皮案震驚了整個(gè)濱河市牲剃,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌雄可,老刑警劉巖凿傅,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異数苫,居然都是意外死亡聪舒,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門虐急,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)箱残,“玉大人,你說我怎么就攤上這事止吁【斡睿” “怎么了?”我有些...
    開封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵赏殃,是天一觀的道長(zhǎng)敷待。 經(jīng)常有香客問我,道長(zhǎng)仁热,這世上最難降的妖魔是什么榜揖? 我笑而不...
    開封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮抗蠢,結(jié)果婚禮上举哟,老公的妹妹穿的比我還像新娘。我一直安慰自己迅矛,他們只是感情好妨猩,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著秽褒,像睡著了一般壶硅。 火紅的嫁衣襯著肌膚如雪威兜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天庐椒,我揣著相機(jī)與錄音椒舵,去河邊找鬼。 笑死约谈,一個(gè)胖子當(dāng)著我的面吹牛笔宿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播棱诱,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼泼橘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了迈勋?” 一聲冷哼從身側(cè)響起炬灭,我...
    開封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎粪躬,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體昔穴,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡镰官,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了吗货。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片泳唠。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖宙搬,靈堂內(nèi)的尸體忽然破棺而出笨腥,到底是詐尸還是另有隱情,我是刑警寧澤勇垛,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布脖母,位于F島的核電站,受9級(jí)特大地震影響闲孤,放射性物質(zhì)發(fā)生泄漏谆级。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一讼积、第九天 我趴在偏房一處隱蔽的房頂上張望肥照。 院中可真熱鬧,春花似錦勤众、人聲如沸舆绎。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)吕朵。三九已至猎醇,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間边锁,已是汗流浹背姑食。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留茅坛,地道東北人音半。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像贡蓖,于是被迫代替她去往敵國(guó)和親曹鸠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • //無(wú)向圖 //默認(rèn)從V0開始 #include #include #include using namespac...
    天線斑斑閱讀 384評(píng)論 0 0
  • //正確 //現(xiàn)為無(wú)向圖 //但是一下改成有向圖好像有點(diǎn)不對(duì)斥铺,要琢磨下 #include #include //...
    天線斑斑閱讀 1,077評(píng)論 0 0
  • 題目類型 a.C++與C差異(1-18) 1.C和C++中struct有什么區(qū)別彻桃? C沒有Protection行為...
    阿面a閱讀 7,663評(píng)論 0 10
  • /無(wú)向圖 //正確,無(wú)向圖可以改成有向圖\ //如果用模板晾蜘,要記得 //template <class T> //...
    天線斑斑閱讀 317評(píng)論 0 0
  • 各校歷年復(fù)試機(jī)試試題 清華邻眷、北大、華科試題詳細(xì)筆記部分剔交,少筆記部分與少數(shù)leetcode【含個(gè)人整理筆記】 一肆饶、詳...
    十里江城閱讀 1,187評(píng)論 0 1