青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

yuanyuelang

常用鏈接

統計

最新評論

最小生成樹之Kruskal算法

最小生成樹是圖論的一個重要部分,解決這個問題的算法主要有Kruskal算法和Prim算法。

最小生成樹:顧名思義是一棵樹,該樹是圖中權值和最小的。

我們先來介紹Kruskal算法,Prim算法請參閱最小生成樹之Prim算法

該算法的基本思路:貪心,如何貪心呢?
它的貪心準則是:
1.每次從剩下的邊中選擇一個不會產生環路而且權值最小的邊加入到已經選擇好的邊的集合中。
2.它需要e步的操作,e表示圖的邊數,我們可以按權值排好序后,對每一條邊進行選擇,如果加入到已經選擇好的邊中會產生回路的現象,就不要了。。。否則加入到已經選擇好的邊中。
3.我們還需用到并查集的思想,有關并查集的介紹,請查看我的另一篇博文 不相交集合數據結構
4.復雜度:O(ElgE),其中E為圖的邊數

接下來我們引用POJ上的一個經典題目來分析,題目網址http://acm.pku.edu.cn/JudgeOnline/problem?id=1861

題目大意是:題目給出的是圖的頂點和所有邊的集合,要求輸出的是最小生成樹的邊

我們來看下源碼啦:
#include<iostream>
using namespace std;
#include
<algorithm>
#include 
<memory.h>

#define MAXEDGE 15001//最大邊數
#define MAXNODE 1001 //最大節點數

int p[MAXNODE],rank[MAXNODE];//用于不相交集合
int start[MAXEDGE],end[MAXEDGE],weight[MAXEDGE],VNum,ENum;//分別為邊的起點,終點,權重,節點數和邊數
int result_s[MAXEDGE],result_e[MAXEDGE];//分別為存儲最小生成樹的起點,終點
int max_weight,id[MAXEDGE];

void make_set(int x)
{
    p[x]
=x;
    rank[x]
=0;
}


int find_set(int x)

    
if(p[x]!=x)
        p[x]
=find_set(p[x]);
    
return p[x];
}


void Union(int x,int y)
{
    x
=find_set(x);
    y
=find_set(y);
    
if(rank[x]>rank[y])
        p[y]
=x;
    
else if(rank[x]<rank[y])
        p[x]
=y;
    
else if(rank[x]==rank[y])
    
{
        p[x]
=y;
        rank[y]
++;
    }

}


bool cmp(int i,int j)//用于sort函數
{
    
return weight[i]<weight[j];
}

void Kruskal()
{
    
int i,min,index=0,count=0,k=0;
    
    max_weight
=0;
        
for(i=1;i<=VNum;i++)
          make_set(i);
    
        sort(id,id
+ENum,cmp);//對所有邊進行排序,注意id數組的妙用
    while(true){
      min
=id[index++];
      
if(find_set(start[min])!=find_set(end[min]))//對每條邊進行處理,如果起點和終點不在同一集合合并之
        Union(start[min],end[min]);
        result_s[k]
=start[min];//保存結果
                result_e[k++]=end[min];
                count
++;
        
if(max_weight<weight[min])
                max_weight
=weight[min];
       }

      
        
if(count==VNum-1break;//當邊數等于節點數-1的時候表示已經完成
    }

}






int main()
{
    
int i;
    cin
>>VNum>>ENum;
    
for(i=0;i<ENum;i++){
        cin
>>start[i]>>end[i]>>weight[i];
        id[i]
=i;
    }

        Kruskal();
        cout
<<max_weight<<endl<<VNum-1<<endl;
        
for(i=0;i<VNum-1;i++)
       cout
<<result_s[i]<<" "<<result_e[i]<<endl;
   
        
return 0;
}


posted on 2009-09-13 21:18 原語餓狼 閱讀(712) 評論(0)  編輯 收藏 引用 所屬分類: 圖論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美精品黄色| 欧美综合二区| 亚洲色无码播放| 免费不卡在线观看| 久色成人在线| 一区二区三区在线免费视频| 亚洲欧美成人| 久久国产精品网站| 一区二区在线不卡| 欧美激情第三页| 国产精品99久久久久久久女警 | 亚洲欧美另类国产| 国产精品久久午夜| 欧美影院久久久| 91久久久在线| 亚洲国产精品久久久久婷婷老年| 欧美久久久久久蜜桃| 亚洲一区二区日本| 美女视频黄 久久| 亚洲麻豆av| 国产一区二区三区成人欧美日韩在线观看 | 国产精品一香蕉国产线看观看| 久久av一区二区三区亚洲| 欧美h视频在线| 亚洲午夜91| 亚洲日本欧美天堂| 国产欧美精品在线观看| 欧美成人在线免费视频| 日韩亚洲精品视频| 欧美色精品在线视频| 性视频1819p久久| 免费观看欧美在线视频的网站| 亚洲美女淫视频| 国产一区二区三区久久久| 欧美激情精品久久久久久黑人 | 久久在线视频在线| 亚洲一区二区在线免费观看视频| 韩国女主播一区二区三区| 欧美日韩精品欧美日韩精品| 久久久久国产一区二区三区| 亚洲视频 欧洲视频| 欧美激情精品久久久六区热门| 亚洲在线1234| 一区二区高清| 日韩写真视频在线观看| 在线成人av| 国产亚洲成av人在线观看导航| 欧美涩涩网站| 欧美日韩成人在线| 欧美精品久久久久久久久久| 久久午夜精品一区二区| 久久久国产视频91| 亚洲欧美在线视频观看| 宅男66日本亚洲欧美视频| 99成人在线| 亚洲免费观看在线观看| 亚洲黄色视屏| 亚洲国产精品久久久久秋霞蜜臀 | 久久久精彩视频| 亚洲欧美日韩一区二区三区在线| 9人人澡人人爽人人精品| 亚洲精品欧美精品| 亚洲精品国产精品国自产在线| 1000部精品久久久久久久久| 尤物精品国产第一福利三区| 1024精品一区二区三区| 91久久嫩草影院一区二区| 亚洲国产一区二区三区在线播| 亚洲二区视频| 日韩午夜在线播放| 午夜亚洲激情| 久久久久一区二区| 久久亚洲国产精品一区二区| 欧美ed2k| 亚洲精品免费一区二区三区| 国产自产高清不卡| 欧美视频在线观看 亚洲欧| 欧美成人嫩草网站| 欧美片在线观看| 国产精品老牛| 狠狠久久亚洲欧美专区| 亚洲国产天堂久久国产91| 99re6热只有精品免费观看| 一本色道久久88亚洲综合88| 一区二区日韩精品| 午夜国产精品影院在线观看| 久久精品综合网| 欧美国产丝袜视频| 夜夜嗨av一区二区三区网站四季av| 99亚洲一区二区| 午夜欧美理论片| 欧美高清在线视频观看不卡| 国产精品老牛| 亚洲精品乱码久久久久久久久 | 久久久久综合| 欧美视频四区| 黄色成人av| 亚洲午夜视频在线| 美女精品在线观看| 亚洲欧美日韩区| 欧美精品一区三区| 一区视频在线播放| 欧美一区二区视频97| 亚洲区一区二区三区| 久久国产精品一区二区三区| 欧美日韩高清免费| 亚洲国产精品传媒在线观看| 欧美一区二区视频在线| 日韩视频在线播放| 欧美黄色精品| 在线观看福利一区| 久久精品国产一区二区三区| 亚洲精选一区二区| 久久免费国产精品| 韩国av一区| 欧美在线观看你懂的| 中日韩男男gay无套 | 久久婷婷国产综合精品青草| 国产精品午夜视频| 亚洲图片欧美一区| 亚洲日本理论电影| 欧美aⅴ99久久黑人专区| 韩国av一区二区| 久久久www成人免费精品| 在线亚洲+欧美+日本专区| 欧美激情综合网| 亚洲第一福利视频| 欧美激情视频网站| 欧美国产日韩一区| 日韩视频在线你懂得| 影音先锋久久久| 99精品热6080yy久久| 亚洲黄色片网站| 欧美人在线视频| 一区二区三区高清视频在线观看| 亚洲黄色av一区| 欧美日韩国语| 午夜视频在线观看一区二区| 亚洲欧美日韩区| 在线观看日韩av| 亚洲丁香婷深爱综合| 欧美电影免费观看网站| 日韩午夜av电影| 在线一区二区三区四区| 亚洲精品护士| 欧美日韩国产美女| 亚洲一区精品电影| 午夜免费在线观看精品视频| 国内精品久久久久影院优| 美女999久久久精品视频| 久久se精品一区精品二区| 在线观看视频欧美| 亚洲人屁股眼子交8| 国产精品美女www爽爽爽视频| 久久99在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲九九精品| 亚洲免费综合| 亚洲日本中文字幕免费在线不卡| 日韩午夜免费| 国产伊人精品| 亚洲精品日韩激情在线电影| 国产精品久久久久毛片软件| 久久久亚洲国产天美传媒修理工| 欧美刺激性大交免费视频| 亚洲欧美另类中文字幕| 浪潮色综合久久天堂| 亚洲性图久久| 久久美女性网| 先锋影音网一区二区| 欧美jizzhd精品欧美巨大免费| 亚洲嫩草精品久久| 免费成人毛片| 久久久国产午夜精品| 国产精品久久久久久久一区探花 | 日韩一级二级三级| 久久精品国产精品亚洲精品| 一本在线高清不卡dvd| 久久综合九九| 久久艳片www.17c.com| 欧美三区美女| 亚洲精品永久免费| 亚洲电影免费观看高清完整版在线观看 | 欧美精品久久99| 久久精品一区二区三区不卡| 欧美黑人国产人伦爽爽爽| 久久久99免费视频| 国产精品乱码久久久久久| 亚洲观看高清完整版在线观看| 国产一区二区无遮挡| 亚洲午夜性刺激影院| 9国产精品视频| 欧美精品一区二区三区一线天视频| 久久婷婷丁香| 国产日韩精品在线播放| 亚洲私人影吧| 亚洲网址在线| 国产精品jizz在线观看美国| 亚洲精品乱码| 亚洲乱码国产乱码精品精|