JavaScript數(shù)據(jù)結(jié)構(gòu)17——最小生成樹(shù)Kruskal算法

Kruskal算法,克魯斯卡爾算法的精巧和重心在于朽们,提前將邊進(jìn)行了排序的烁。

//Kruskal算法(需要調(diào)用邊集數(shù)組完成)
//創(chuàng)建邊集數(shù)組基本列
function Row(begin,end,weight) {
  this.begin = begin;
  this.end =end;
  this.weight = weight;
}
//創(chuàng)建邊集數(shù)組
function Edges(numV){
  this.edges = [];
  this.numV = numV;
}
//增加邊集數(shù)組添加方法
Edges.prototype.addRow = function(row) {
  this.edges.push(row);
};
//最小生成樹(shù)運(yùn)算方案(克魯斯卡爾)
Edges.prototype.miniSpanTree_Krukal = function(){
  Array.prototype.Find = function(f){
    var f;
    while(this[f]>0){
      f = this[f];
    }
    return f;
  }
  var parent =[];
  var n,m;
  for (var i = 0; i < this.numV; i++) {
    parent.push(0);
  }
  for (var i = 0; i < this.edges.length; i++) {
    n = parent.Find(this.edges[i].begin);
    m = parent.Find(this.edges[i].end);
    if(n!=m){
      parent[n] = m;
      console.info('('+this.edges[i].begin+','+
        this.edges[i].end
        +'),'+this.edges[i].weight)
    }
  }
}
//創(chuàng)建一個(gè)邊集數(shù)組(點(diǎn)直接用數(shù)字表示奶镶,不創(chuàng)建NODE對(duì)象了)!!!邊集數(shù)組的權(quán)值是從小到大排序的
var e = new Edges(9);
e.addRow(new Row(4,7,7));
e.addRow(new Row(2,8,8));
e.addRow(new Row(0,1,10));
e.addRow(new Row(0,5,11));
e.addRow(new Row(1,8,12));
e.addRow(new Row(3,7,16));
e.addRow(new Row(1,6,16));
e.addRow(new Row(5,6,17));
e.addRow(new Row(1,2,18));
e.addRow(new Row(6,7,19));
e.addRow(new Row(3,4,20));
e.addRow(new Row(3,8,21));
e.addRow(new Row(2,3,22));
e.addRow(new Row(3,6,24));
e.addRow(new Row(4,5,26));
console.info(e);
e.miniSpanTree_Krukal();

輸出

Edges {
edges:
[ Row { begin: 1, end: 2, weight: 18 },
Row { begin: 4, end: 7, weight: 7 },
Row { begin: 2, end: 8, weight: 8 },
Row { begin: 0, end: 1, weight: 10 },
Row { begin: 0, end: 5, weight: 11 },
Row { begin: 1, end: 8, weight: 12 },
Row { begin: 3, end: 7, weight: 16 },
Row { begin: 1, end: 6, weight: 16 },
Row { begin: 5, end: 6, weight: 17 },
Row { begin: 6, end: 7, weight: 19 },
Row { begin: 3, end: 4, weight: 20 },
Row { begin: 3, end: 8, weight: 21 },
Row { begin: 2, end: 3, weight: 22 },
Row { begin: 3, end: 6, weight: 24 },
Row { begin: 4, end: 5, weight: 26 } ],
numV: 9 }
(1,2),18
(4,7),7
(2,8),8
(0,1),10
(0,5),11
(3,7),16
(1,6),16
(6,7),19
[Finished in 0.1s]

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末迟赃,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子厂镇,更是在濱河造成了極大的恐慌捺氢,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件剪撬,死亡現(xiàn)場(chǎng)離奇詭異摄乒,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門(mén)馍佑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)斋否,“玉大人,你說(shuō)我怎么就攤上這事拭荤∫鸪簦” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵舅世,是天一觀的道長(zhǎng)旦委。 經(jīng)常有香客問(wèn)我,道長(zhǎng)雏亚,這世上最難降的妖魔是什么缨硝? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮罢低,結(jié)果婚禮上查辩,老公的妹妹穿的比我還像新娘。我一直安慰自己网持,他們只是感情好宜岛,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著功舀,像睡著了一般萍倡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上辟汰,一...
    開(kāi)封第一講書(shū)人閱讀 49,185評(píng)論 1 284
  • 那天列敲,我揣著相機(jī)與錄音,去河邊找鬼莉擒。 笑死酿炸,一個(gè)胖子當(dāng)著我的面吹牛瘫絮,可吹牛的內(nèi)容都是我干的涨冀。 我是一名探鬼主播,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼麦萤,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼鹿鳖!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起壮莹,我...
    開(kāi)封第一講書(shū)人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤翅帜,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后命满,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體涝滴,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了歼疮。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片杂抽。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖韩脏,靈堂內(nèi)的尸體忽然破棺而出缩麸,到底是詐尸還是另有隱情,我是刑警寧澤赡矢,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布杭朱,位于F島的核電站,受9級(jí)特大地震影響吹散,放射性物質(zhì)發(fā)生泄漏弧械。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一送浊、第九天 我趴在偏房一處隱蔽的房頂上張望梦谜。 院中可真熱鬧,春花似錦袭景、人聲如沸唁桩。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)荒澡。三九已至,卻和暖如春与殃,著一層夾襖步出監(jiān)牢的瞬間单山,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工幅疼, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留米奸,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓爽篷,卻偏偏與公主長(zhǎng)得像悴晰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子逐工,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344

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