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

bon

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

常用鏈接

留言簿(2)

我參與的團(tuán)隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜


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

  1 // 這個算法用kruskal實現(xiàn)了
  2 #include <iostream>
  3 #include <algorithm>
  4 
  5 using namespace std;
  6 
  7 const int maxn=100;
  8 
  9 int m[maxn];
 10 // 邊的結(jié)構(gòu)體
 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 // 邊數(shù)
 23 int ce;
 24 // 點數(shù)
 25 int n;
 26 int heap[maxn];
 27 // 堆大小
 28 int hsize;
 29 
 30 void merge(int i,int j)
 31 {
 32     // i所代表的集合中元素數(shù)小于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(luò)路徑上所有點的父親設(shè)為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)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   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久久精品一区二区别| 欧美在线免费视屏| 国产精品任我爽爆在线播放| 一本久久综合| 日韩亚洲欧美成人| 欧美日韩精品一区| 亚洲精品中文字幕女同| 欧美黄色一级视频| 噜噜爱69成人精品| 亚洲精品免费在线| 欧美日韩国产色综合一二三四 | 久久亚裔精品欧美| 激情综合色综合久久综合| 久久在线视频在线| 美女视频黄免费的久久| 亚洲精品欧美日韩专区| 亚洲黄色av| 欧美日韩日日夜夜| 亚洲欧美日韩国产| 午夜精品福利一区二区蜜股av| 国产精品一区二区三区乱码| 欧美尤物一区| 久久久久五月天| 亚洲伦理在线观看| 一本一本a久久| 国产亚洲精品自拍| 美日韩免费视频| 欧美激情中文字幕乱码免费| 亚洲午夜视频在线观看| 亚洲综合第一页| 在线观看视频欧美| 亚洲免费高清视频| 国产一区二区主播在线| 欧美国产一区二区在线观看| 欧美精品电影在线| 午夜精品视频在线观看| 久久久久国产成人精品亚洲午夜| 最新国产成人av网站网址麻豆| 99re热精品| 国内成人精品视频| 亚洲日本无吗高清不卡| 国产日产精品一区二区三区四区的观看方式 | 黄色精品一二区| 亚洲激情视频在线| 国产精品一区二区女厕厕| 免费成人av| 国产精品久久久久久av福利软件 | 久久久视频精品| 亚洲天堂久久| 久久av一区二区三区| 一本色道久久加勒比精品| 香蕉久久夜色精品国产| 91久久夜色精品国产九色| 亚洲专区一区二区三区| 亚洲日韩欧美视频| 欧美在线视频日韩| 亚洲一区二区三区国产| 美女爽到呻吟久久久久| 久久精品1区| 欧美丝袜一区二区三区| 国产精品网曝门| 亚洲福利专区| 国语自产精品视频在线看| 一区二区三区四区在线| 亚洲级视频在线观看免费1级| 午夜精品国产更新| 亚洲影院色无极综合| 欧美二区视频| 玖玖精品视频| 国产日韩欧美精品| 亚洲深夜激情| 亚洲国产欧美一区二区三区同亚洲| 亚洲欧美电影在线观看| 亚洲午夜一区二区三区| 欧美成人免费在线观看| 蜜臀久久99精品久久久久久9| 国产日韩欧美在线播放| 一本色道久久综合狠狠躁的推荐| 亚洲国产精品一区在线观看不卡| 欧美一二三区精品| 欧美亚洲日本一区| 国产精品视频一区二区三区| 中文一区二区在线观看| 在线视频日韩| 欧美日韩高清在线播放| 91久久精品国产91性色| 亚洲精品一区二区在线| 欧美大片国产精品| 亚洲电影av| 99pao成人国产永久免费视频| 另类欧美日韩国产在线| 久久亚洲图片| 在线视频国内自拍亚洲视频| 久久亚洲国产成人| 久久久夜夜夜| 在线欧美三区| 免费91麻豆精品国产自产在线观看| 在线成人免费观看| 亚洲高清在线精品| 亚洲精品影院| 国产一区自拍视频| 欧美一区三区二区在线观看| 久久都是精品| 欧美在线免费观看视频| 亚洲欧美日韩另类| 亚洲午夜国产成人av电影男同| 久久精品一区二区三区四区| 国产午夜精品美女视频明星a级| 亚洲视频在线观看免费| 亚洲免费视频中文字幕| 国产精品视频自拍| 久久九九热免费视频| 美女网站在线免费欧美精品| 亚洲国产免费| 欧美日韩99| 亚洲一区二区在线免费观看视频 | 亚洲系列中文字幕| 欧美一区网站| 韩国女主播一区二区三区| 牛牛影视久久网| 亚洲乱码精品一二三四区日韩在线 | 午夜欧美精品| 国产精品人人爽人人做我的可爱| 欧美一乱一性一交一视频| 欧美日本一道本| 99re66热这里只有精品4| 欧美一乱一性一交一视频| 亚洲成色精品| 欧美性做爰猛烈叫床潮| 欧美在线播放高清精品| 亚洲啪啪91| 久久久中精品2020中文| 亚洲美女精品成人在线视频| 国产精品久久久久久久久果冻传媒 | 中文国产一区| 韩日视频一区| 欧美日韩亚洲91| 欧美成人国产一区二区| 亚洲视频视频在线| 一色屋精品视频在线看| 欧美系列电影免费观看| 久久午夜av| 一本色道久久88精品综合| 麻豆免费精品视频| 亚洲欧美综合网| 99精品视频网| 亚洲国产欧美另类丝袜| 国产噜噜噜噜噜久久久久久久久| 欧美国产综合视频| 久久久激情视频| 香蕉乱码成人久久天堂爱免费 | 亚洲欧美日韩直播| 国产精品羞羞答答xxdd| 久热爱精品视频线路一| 亚洲美女在线国产| 欧美成在线观看| 久久精品一区蜜桃臀影院| 一区二区三区四区五区精品| 亚洲韩国日本中文字幕| 国产最新精品精品你懂的| 国产精品成人一区| 欧美激情片在线观看| 玖玖精品视频| 久久免费视频在线观看| 久久精品系列| 久久久久久97三级| 久久福利影视| 久久国产精彩视频| 久久精品国产精品亚洲精品| 欧美自拍偷拍午夜视频| 欧美一区二区高清在线观看| 亚洲一区二区四区| 蜜桃久久av一区| 久久久青草青青国产亚洲免观| 亚洲欧美日韩国产综合| 亚洲专区一区| 国产精品欧美日韩久久| 亚洲免费影视第一页| 亚洲综合色噜噜狠狠| 亚洲欧美视频一区| 亚洲一区二区毛片| 亚洲欧美在线免费| 欧美一区二区三区喷汁尤物| 欧美一级黄色录像| 久久久国产91| 奶水喷射视频一区| 欧美日韩黄色大片| 欧美成人精品| 欧美电影资源| 日韩天堂在线视频| 亚洲欧美日韩在线一区| 欧美永久精品| 午夜在线不卡| 牛牛精品成人免费视频| 欧美一区三区二区在线观看|