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

bon

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  46 Posts :: 0 Stories :: 12 Comments :: 0 Trackbacks

常用鏈接

留言簿(2)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜


廢話少說,下面是大家都熟悉的kruskal算法,重點在于實現,時間復雜度為O(e*loge),其中e為邊數。

  1 // 這個算法用kruskal實現了
  2 #include <iostream>
  3 #include <algorithm>
  4 
  5 using namespace std;
  6 
  7 const int maxn=100;
  8 
  9 int m[maxn];
 10 // 邊的結構體
 11 struct node{
 12     int u,v;
 13     double cost;
 14     bool operator <(node a)
 15     {
 16         return cost>a.cost;
 17     }
 18 }e[maxn];
 19 
 20 
 21 
 22 // 邊數
 23 int ce;
 24 // 點數
 25 int n;
 26 int heap[maxn];
 27 // 堆大小
 28 int hsize;
 29 
 30 void merge(int i,int j)
 31 {
 32     // i所代表的集合中元素數小于j所代表的
 33     if(m[i]>m[j]){
 34         m[j]+=m[i];
 35         m[i]=j;
 36     }else{
 37         m[i]+=m[j];
 38         m[j]=i;
 39     }
 40 }
 41 
 42 int find(int i)
 43 {
 44     int j,k,t;
 45     // 從i回溯到根
 46     for(j=i;m[j]>0;j=m[j]);
 47     // 路徑壓縮,將從i到j路徑上所有點的父親設為j
 48     for(k=i;k!=j;k=t){
 49         t=m[k];
 50         m[k]=j;
 51     }
 52     return j;
 53 }
 54 
 55 void init()
 56 {
 57     memset(m,-1,sizeof(m));
 58     return;
 59 }
 60 
 61 void siftdown(int index)
 62 {
 63     heap[index]=heap[hsize];
 64     hsize--;
 65     int i=index,j,tmp;
 66     while(2*i<=hsize){
 67         j=2*i;
 68         if(j+1<=hsize && e[heap[j+1]].cost>e[heap[j]].cost) j++;
 69         if(e[heap[i]].cost>e[heap[j]].cost) break;
 70         tmp=heap[i];
 71         heap[i]=heap[j];
 72         heap[j]=tmp;
 73         i=j;
 74     }
 75 }
 76 
 77 int extract()
 78 {
 79     int res=heap[1];
 80     siftdown(1);
 81     return res;
 82 }
 83 
 84 void siftup(int index)
 85 {
 86     int i=index,tmp;
 87     while(i>1 && e[heap[i/2]].cost<e[heap[i]].cost){
 88         tmp=heap[i/2];
 89         heap[i/2]=heap[i];
 90         heap[i]=tmp;
 91         i/=2;
 92     }
 93 }
 94 
 95 
 96 // 用kruskal求最大生成樹
 97 void kruskal()
 98 {
 99     // 初始化并查集
100     init();
101     int i;
102     // 初始化堆
103     //sort(e+1,e+ce+1);
104     for(i=1;i<=ce;i++){
105         heap[i]=i;
106         siftup(i);
107     }
108     hsize=ce;
109     // 算法開始
110     double total=0.0;
111     int mergeTime=0;    // 只需合并n-1次
112     int a,b;
113     while(hsize>0 && mergeTime<n-1){
114         i=extract();
115         a=find(e[i].u);
116         b=find(e[i].v);
117         // 若a,b處在不同的集合中
118         if(a!=b){
119             merge(a,b);
120             total+=e[i].cost;
121             printf("merge edge(%d,%d) with cost %.2lf\n",e[i].u,e[i].v,e[i].cost);
122         }
123     }
124     printf("total cost %.2lf\n:",total);
125     return;
126 }
127 
128 int main()
129 {
130     freopen("graph.txt","r",stdin);
131     scanf("%d%d",&n,&ce);
132     int i,j,k,c;
133     for(i=1;i<=ce;i++) scanf("%d%d%lf",&e[i].u,&e[i].v,&e[i].cost);
134     kruskal();
135     return 1;
136 }
posted on 2008-05-02 23:07 bon 閱讀(1337) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


Google PageRank 
Checker - Page Rank Calculator
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美电影在线| 欧美在线观看一区| 亚洲欧美福利一区二区| 欧美日韩日本国产亚洲在线| 亚洲电影在线| 欧美三级资源在线| 亚洲精品国产拍免费91在线| 亚洲第一精品久久忘忧草社区| 欧美aⅴ99久久黑人专区| 国产精品99久久久久久白浆小说| 亚洲国产精品t66y| 国产精品美女久久| 免费在线看成人av| 国产欧美一区二区精品性色| 久久频这里精品99香蕉| 久久亚洲精品一区二区| 99香蕉国产精品偷在线观看| 亚洲美女尤物影院| 亚洲国产免费| 亚洲免费观看高清完整版在线观看熊| 欧美成年人网| 亚洲第一精品福利| 这里只有精品电影| 国产欧美日韩视频在线观看| 亚洲色图综合久久| 久久国产精品亚洲va麻豆| 久久久精品国产一区二区三区| 国产精品亚洲产品| 欧美激情精品| 日韩亚洲视频| 欧美日韩免费观看中文| 国产一区二区三区最好精华液| 欧美成人一区二区在线| 欧美揉bbbbb揉bbbbb| 一片黄亚洲嫩模| 亚洲精品色婷婷福利天堂| 欧美激情亚洲一区| 亚洲黄色在线视频| 亚洲黄色成人久久久| 模特精品在线| 日韩视频一区二区三区| 一区二区欧美视频| 欧美国产1区2区| 在线看一区二区| 另类专区欧美制服同性| 91久久国产综合久久| 亚洲日韩欧美视频| 国产乱码精品一区二区三区忘忧草 | 麻豆久久久9性大片| 国产综合色在线| 欧美高清在线观看| 一区二区三区日韩精品| 久久国内精品视频| 亚洲精品一品区二品区三品区| 国产精品美女久久久| 一区二区三区四区精品| 国产女主播在线一区二区| 欧美日韩黄色大片| 美女脱光内衣内裤视频久久网站| 亚洲欧美日本视频在线观看| 国产亚洲欧美日韩一区二区| 亚洲女性喷水在线观看一区| 在线亚洲欧美视频| 美女91精品| 久久综合色影院| 久久综合网hezyo| 亚洲国产精品成人精品| 一本色道88久久加勒比精品| 欧美有码视频| 老巨人导航500精品| 欧美一区二区三区在线播放| 亚洲永久免费观看| 欧美一区二区女人| 久久一本综合频道| 久久久精品欧美丰满| 久久精品国产精品| 久久精品欧洲| 欧美一区二区三区四区高清| 亚洲视频在线一区| 午夜国产精品影院在线观看 | 欧美a级大片| 麻豆av一区二区三区久久| 久久人人爽人人| 欧美激情第六页| 一区二区三区不卡视频在线观看| 日韩午夜激情电影| 亚洲欧洲美洲综合色网| 亚洲无毛电影| 在线一区欧美| 久久久国产精彩视频美女艺术照福利| 老司机午夜免费精品视频| 亚洲国产婷婷香蕉久久久久久99| 亚洲欧洲在线看| 亚洲欧美日韩国产成人| 牛夜精品久久久久久久99黑人| 欧美日韩国产免费| 国外成人在线视频网站| 日韩视频精品| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲人被黑人高潮完整版| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲欧美综合v| 欧美激情亚洲自拍| 韩国欧美国产1区| 午夜久久99| 一片黄亚洲嫩模| 欧美日韩在线一区| 99精品欧美一区二区蜜桃免费| 久久蜜桃资源一区二区老牛 | 午夜亚洲性色福利视频| 欧美精品久久久久久久免费观看 | 亚洲少妇自拍| 老色批av在线精品| 伊人久久大香线蕉av超碰演员| 午夜视频久久久久久| 亚洲三级免费电影| 欧美成人免费在线观看| 久久久久久久性| 亚洲黄色性网站| 亚洲精品自在久久| 国产精品第十页| 欧美伊人久久久久久久久影院| 亚洲欧美日韩精品久久久久| 国产亚洲精品aa午夜观看| 欧美18av| 欧美视频中文一区二区三区在线观看 | 欧美黄色日本| 一二三区精品福利视频| 99这里有精品| 国内精品99| 亚洲日本成人| 国产一区二区成人久久免费影院| 久久精品夜夜夜夜久久| 免费久久99精品国产自| 欧美在线一二三| 亚洲美女中文字幕| 亚洲欧美网站| 亚洲性感美女99在线| 欧美在线电影| 亚洲欧美国产精品桃花| 欧美 日韩 国产 一区| 久久精品91| 欧美激情免费观看| 欧美11—12娇小xxxx| 免费久久99精品国产自| aⅴ色国产欧美| 亚洲人成在线影院| 久久久久久久久综合| 欧美在线一级视频| 国产精品久久久久9999高清| 乱中年女人伦av一区二区| 国产精品日韩在线| 亚洲视频www| 久久国产免费看| 国产精品一区免费观看| 一区二区三区精品视频| 一本色道久久综合亚洲91| 免费成人高清视频| 欧美激情片在线观看| 亚洲久久一区二区| 欧美日韩成人综合| 亚洲一区国产视频| 久久精品夜色噜噜亚洲aⅴ| 国内精品国语自产拍在线观看| 亚洲欧美视频在线观看视频| 久久天天躁狠狠躁夜夜av| 在线成人免费观看| 欧美大片在线观看一区| 在线观看日韩av先锋影音电影院| 久久精品免费| 亚洲精品久久久久中文字幕欢迎你 | 欧美在线高清视频| 欧美高清在线精品一区| 亚洲欧美成人网| 久久视频在线看| 日韩午夜电影| 国产女主播在线一区二区| 久久久成人网| 99精品视频免费全部在线| 久久精品亚洲| 一个色综合导航| 国产自产在线视频一区| 欧美午夜片在线观看| 久久久噜噜噜| 亚洲欧美日韩在线高清直播| 欧美成人乱码一区二区三区| 亚洲深夜福利| 在线成人国产| 国产亚洲福利| 国产精品一级在线| 欧美视频一区在线观看| 欧美精品久久99久久在免费线| 免费在线欧美黄色| 久久久精品网| 久久欧美肥婆一二区| 性8sex亚洲区入口| 午夜国产精品视频免费体验区| 亚洲美女一区| 亚洲午夜电影网| 亚洲免费在线|