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

bon

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

常用鏈接

留言簿(2)

我參與的團(tuán)隊(duì)

搜索

  •  

最新評(píng)論

  • 1.?re: pku 1861
  • 評(píng)論內(nèi)容較長(zhǎng),點(diǎn)擊標(biāo)題查看
  • --edward2
  • 2.?re: pku 3349
  • 大哥超時(shí) 勒
  • --sum
  • 3.?re: pku 3070
  • 學(xué)習(xí)下,哇哈哈
  • --bear
  • 4.?re: poj 3340
  • 不用DFS的,直接有數(shù)學(xué)規(guī)律的,找出滿(mǎn)足條件的最小的數(shù)就可以了
  • --czcomt
  • 5.?re: pku 3070
  • 方法不錯(cuò)額~~~
  • --Zeor

閱讀排行榜

評(píng)論排行榜


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

  1 // 這個(gè)算法用kruskal實(shí)現(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 // 點(diǎn)數(shù)
 25 int n;
 26 int heap[maxn];
 27 // 堆大小
 28 int hsize;
 29 
 30 void merge(int i,int j)
 31 {
 32     // i所代表的集合中元素?cá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ò)路徑上所有點(diǎn)的父親設(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求最大生成樹(shù)
 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     // 算法開(kāi)始
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) 評(píng)論(0)  編輯 收藏 引用

只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   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>
            久久日韩精品| 99精品视频免费| 欧美国产大片| 亚洲调教视频在线观看| 欧美日本视频在线| 亚洲欧美日韩人成在线播放| 在线视频中文亚洲| 国产精品99久久久久久久久| 亚洲一二三区精品| 亚洲精品久久久久| 亚洲精品少妇30p| 亚洲欧美激情视频在线观看一区二区三区| 99精品国产热久久91蜜凸| 中文国产成人精品久久一| 亚洲欧美日韩国产综合精品二区 | 欧美国产精品劲爆| 亚洲人成7777| 欧美一区二区私人影院日本 | 午夜亚洲一区| 另类激情亚洲| 欧美日本高清视频| 国产在线欧美| 亚洲伦理在线免费看| 亚洲视频在线观看一区| 一区二区三区日韩欧美| 久久男人资源视频| 夜夜嗨av一区二区三区四季av| 欧美伊人久久大香线蕉综合69| 可以看av的网站久久看| 国产噜噜噜噜噜久久久久久久久| 精品成人在线观看| 欧美中文字幕视频在线观看| 亚洲毛片在线看| 欧美二区在线观看| 午夜精品免费| 国产精品久久久久影院色老大| 日韩亚洲成人av在线| 男女激情视频一区| 欧美不卡在线视频| 亚洲精品之草原avav久久| 国产精品成人在线观看| 亚洲视频一区在线观看| 亚洲男人的天堂在线aⅴ视频| 国产精品视频不卡| 久久综合五月| 欧美精品成人| 香蕉成人啪国产精品视频综合网| 9色国产精品| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲主播在线播放| 久久国内精品视频| 在线观看亚洲专区| 亚洲字幕一区二区| 亚洲高清免费| 亚洲一区二区日本| 亚洲国产欧美一区二区三区同亚洲| 亚洲人成艺术| 精品成人国产| 亚洲性线免费观看视频成熟| 在线观看av不卡| 亚洲免费影视第一页| 91久久在线观看| 久久中文精品| 久久久久综合一区二区三区| 国产精品国产三级国产普通话99| 欧美成人午夜免费视在线看片| 国产精品久久久久久av福利软件| 最新国产の精品合集bt伙计| 影音先锋久久精品| 欧美中文字幕视频在线观看| 欧美成人午夜| 欧美在线观看视频一区二区| 亚洲无亚洲人成网站77777| 久久精品国产一区二区三区| 日韩视频永久免费| 老司机免费视频一区二区| 一区二区三区欧美在线观看| 欧美激情1区2区3区| 欧美激情中文不卡| 亚洲日本一区二区三区| 免费亚洲网站| 欧美a一区二区| 在线国产欧美| 免费久久99精品国产自| 欧美激情精品久久久| 亚洲国产日韩欧美综合久久 | 伊人男人综合视频网| 欧美一区二区三区另类| 亚洲免费影视| 精品成人国产| 欧美国产精品久久| 亚洲综合国产精品| 亚洲国产色一区| 欧美在线999| 91久久国产自产拍夜夜嗨| 欧美日韩综合另类| 久久久久国产精品人| 亚洲一区三区视频在线观看| 亚洲第一区在线观看| 久久嫩草精品久久久久| 中文日韩欧美| 宅男在线国产精品| 精品91在线| 国产亚洲精品久久久久久| 欧美日韩一区在线视频| 亚洲高清久久| 午夜精品www| 亚洲高清在线| 欧美午夜精品久久久久久超碰| 亚洲视频在线观看| 欧美高清在线视频观看不卡| 亚洲午夜国产成人av电影男同| 在线观看国产精品网站| 国产农村妇女精品一二区| 欧美日韩精品免费观看视一区二区| 久久久久国产精品厨房| 午夜亚洲视频| 亚洲专区一区| 久久大逼视频| 免费日韩视频| 欧美性色视频在线| 国产精品免费观看在线| 国产人成一区二区三区影院| 国产欧美一区二区精品忘忧草| 国产主播一区二区三区| 亚洲大胆人体视频| 亚洲乱码国产乱码精品精天堂 | 国内外成人在线| 国产精品一区二区视频| 国产一区二区三区四区五区美女 | 午夜精品久久久久久99热软件| 欧美一区二区三区久久精品茉莉花 | 亚洲美女性视频| 99国产精品99久久久久久| 亚洲性夜色噜噜噜7777| 久久人人97超碰精品888| 欧美粗暴jizz性欧美20| 欧美性猛片xxxx免费看久爱| 国内精品一区二区| 日韩亚洲欧美高清| 欧美+日本+国产+在线a∨观看| 亚洲美女黄网| 久久久美女艺术照精彩视频福利播放 | 欧美国内亚洲| 狠狠色综合网| 久久久久一区二区| 99riav久久精品riav| 另类酷文…触手系列精品集v1小说| 欧美日韩免费一区二区三区| 亚洲国产精品第一区二区| 久久精品国产亚洲aⅴ| 亚洲大胆在线| 亚洲黄色免费| 免费观看亚洲视频大全| 亚洲影院在线观看| 亚洲综合色自拍一区| 欧美视频在线播放| 亚洲在线播放| 亚洲欧美日韩系列| 黄色在线一区| 亚洲黄网站黄| 国产毛片精品国产一区二区三区| 久久成人久久爱| 欧美福利一区二区| 一区二区三区视频免费在线观看| 99国产精品久久久久老师| 国产精品久久久久久久7电影 | 午夜视黄欧洲亚洲| 亚洲一区二区三区四区五区午夜 | 国产精品久久久久久久久久直播| 欧美精品久久久久久久免费观看 | 久久久久国产精品一区| 亚洲国内自拍| 久久久久久久综合色一本| 激情小说另类小说亚洲欧美 | 久久国产精品久久国产精品| 欧美精品一区三区在线观看| 欧美mv日韩mv国产网站app| 亚洲成人在线免费| 欧美有码在线观看视频| 麻豆精品视频在线| 一区二区久久久久久| 欧美日韩免费在线| 黄色精品一二区| 亚洲一区二区在线看| 91久久线看在观草草青青| 久久久久久久久久看片| 国产视频在线一区二区| 亚洲国产1区| 久久狠狠一本精品综合网| 欧美h视频在线| 久久美女性网| 亚洲视频免费在线观看| 亚洲欧美日韩一区| 国产精品免费区二区三区观看| 91久久久久| 久久精品国产v日韩v亚洲 | 欧美一级黄色录像| 欧美一区二区三区另类 | 伊人成人开心激情综合网|