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

posts - 99,  comments - 8,  trackbacks - 0

這可是第一個并查積的題目哦!
先從問題的簡單做法入手,構造出原始模型。

如果原始模型是對于集合之間合并處理問題,那么就可以使用并查集使得程序變得高效。

并查集的路徑壓縮只有在元素之間的特性存在遞推關系時才可以使用。

關鍵是要理解那兩個調用的函數,以及用樹結構處理時要注意的問題:
1.合并的時候要注意是將高度較小的樹合并到高度較大的樹,所以小樹的parent指向大樹根節點
2.一定要理解一點就是合并兩個節點實際上是合并他們的根節點,所以一定要找到節點,找到時候理解好也就是為什么findfather中為什么要用while的原因了

//此題運用并查積:就是將所有的村莊放到一個集合中
#include <iostream>
#include <string>
using namespace std;

struct node
{
   int parent;
   int height;
};

node village[1000];

//找根節點 
int findfather (int a)
{
       while ( a != village[a].parent )     //理解while 樹狀結構:找到最終的跟節點
             a = village[a].parent;
             return a;              
}

//合并到同一集合
void merge (int a, int b)      //注意參數:要合并兩個節點的根 
{
     if ( village[a].height == village[b].height )
     {
          village[b].parent = a;
          village[a].height ++;
     }
     
     //小樹合并到大樹 
     else if ( village[a].height > village[b].height ) 
     {
          village[b].parent = a;
     } 
     else
     village[a].parent = b;


int main ()
{
    int n, m;
    while ( scanf ("%d", &n) != EOF && n)
    {
          for (int i = 1; i <= n; i ++)        //根據并查積的算法,先將數組初始化,設定本身為一個獨立的集合,并且高度都是 1 
          {
              village[i].parent = i;
              village[i].height = 1; 
          }
          
          scanf ("%d", &m);
          int a, b;
          int a1, b1;
          for (int i = 0; i < m; i ++)
          {
              scanf ("%d %d", &a, &b);     //找出要并入集合的元素的根,如果根節點相同則不并入同一個集合,反之,則并入到同一個集合
              
              a1 = findfather (a);
              b1 = findfather (b);
              
              if ( a1 != b1 )           //當根節點不同時合并跟節點 
              merge (a1, b1); 
          }
          
          //最后遍歷并查積數組看看一共有幾個不同的集合
          int sum = -1;
          for (int i = 1; i <= n; i ++)
          {
              if ( i == village[i].parent )
               sum ++;
          } 
          printf ("%d\n", sum);
    }

     //system ("pause");
     return 0;
}


 

posted on 2010-08-25 22:48 雪黛依夢 閱讀(306) 評論(0)  編輯 收藏 引用 所屬分類: 并查積
<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

常用鏈接

留言簿(4)

隨筆分類

隨筆檔案

文章檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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国产精品国产精品久久| 母乳一区在线观看| 久久久久国产精品一区三寸| 亚洲欧美国产一区二区三区| 在线视频精品一| 亚洲精品久久久久久下一站| 亚洲第一天堂无码专区| 在线成人av网站| 国内精品伊人久久久久av影院| 国产农村妇女毛片精品久久麻豆 | 久久综合久久综合九色| 午夜欧美视频| 欧美一区二区成人6969| 亚洲欧美日韩视频二区| 亚欧成人精品| 久久国内精品自在自线400部| 欧美一区免费视频| 久久人91精品久久久久久不卡| 久久福利电影| 久久一综合视频| 免费永久网站黄欧美| 欧美国产丝袜视频| 久久精品人人做人人爽电影蜜月| 亚洲国产成人91精品| 毛片基地黄久久久久久天堂| 欧美sm极限捆绑bd| 欧美国产日韩一二三区| 91久久夜色精品国产网站| 日韩性生活视频| 亚洲一区二区三区欧美| 小处雏高清一区二区三区 | 美女诱惑黄网站一区| 老色批av在线精品| 欧美日韩极品在线观看一区| 国产精品久久久久久亚洲调教| 国产精品美女久久久久久免费| 国产精品一级二级三级| 亚洲大胆人体视频| 日韩亚洲视频在线| 国产亚洲午夜高清国产拍精品| 激情五月综合色婷婷一区二区| 亚洲精品亚洲人成人网| 性欧美8khd高清极品| 欧美成人按摩| 一区二区三区四区五区精品| 久久精品国产精品| 欧美视频网址| 在线国产亚洲欧美| 欧美一区二区| 日韩亚洲视频| 久热精品在线| 国产一区二区日韩精品欧美精品| 亚洲日本无吗高清不卡| 久久久精彩视频| 夜夜狂射影院欧美极品| 蜜臀av国产精品久久久久| 国产精品视频九色porn| 一本色道久久88综合亚洲精品ⅰ | 亚洲第一中文字幕在线观看| 亚洲一级在线观看| 欧美激情第4页| 欧美专区日韩视频| 国产精品盗摄久久久| 国产一区二区在线观看免费| 亚洲网站在线观看| 亚洲国产精品尤物yw在线观看 | 国产一区视频观看| 亚洲丝袜av一区| 亚洲国产mv| 久热精品视频在线免费观看| 国内精品免费在线观看| 久久国产精品一区二区三区四区| 99精品免费视频| 欧美福利视频在线| 久久国产精品色婷婷| 久久综合狠狠综合久久激情| 国产视频亚洲精品| 久久精品99国产精品| 亚洲一级片在线观看| 欧美三级免费| 亚洲午夜极品| 亚洲制服av| 国产一区二区毛片| 欧美freesex交免费视频| 久久尤物视频| 日韩视频一区| 野花国产精品入口| 国产精品入口夜色视频大尺度| 小黄鸭视频精品导航| 亚洲欧美日韩精品| 好吊一区二区三区| 欧美国产免费| 欧美理论在线| 午夜精品短视频| 欧美诱惑福利视频| 亚洲国产精品成人精品| 亚洲国产一区二区精品专区| 欧美日韩免费高清| 欧美在线一二三四区| 久久精彩免费视频| 日韩一区二区精品葵司在线| 中日韩在线视频| 国产主播一区二区| 亚洲激情视频| 国产精品国产三级国产专播精品人| 午夜精品一区二区三区在线播放| 亚洲欧美日韩一区二区三区在线观看 | 欧美日韩国产区一| 亚洲国产精品嫩草影院| 美女尤物久久精品| 久热这里只精品99re8久| 亚洲欧洲日韩综合二区| 亚洲精品久久久久久久久久久久久 | 亚洲黄色成人| 亚洲国产专区校园欧美| 欧美日韩高清免费| 亚洲欧美网站| 久久国产欧美| 亚洲精选国产| 亚洲国产成人91精品| 国产尤物精品| 亚洲黄色在线看| 国产精品伦子伦免费视频| 久久精品导航| 欧美成人性生活| 久久久五月婷婷| 欧美午夜精品久久久久久超碰| 香蕉久久夜色精品国产| 久热国产精品视频| 一本色道久久综合亚洲精品高清| 亚洲男女自偷自拍图片另类| 在线观看一区二区视频| 一本大道久久精品懂色aⅴ| 国际精品欧美精品| 亚洲精品欧美激情| 激情伊人五月天久久综合| 99re这里只有精品6| 国内精品福利| 在线午夜精品| 91久久久久久久久久久久久| 久久成人精品电影| 亚洲一区二区免费看| 久久久免费精品视频| 亚洲欧美激情一区| 欧美黄色一区二区| 男女视频一区二区| 在线精品国产成人综合| 亚洲欧美日韩国产中文在线| 在线中文字幕不卡| 欧美成人在线免费观看| 久久亚洲一区二区三区四区| 欧美性生交xxxxx久久久| 夜夜嗨av一区二区三区免费区| 亚洲国产三级| 久久久久在线观看| 久久久99国产精品免费| 国产精品久久久久久久久免费桃花| 亚洲国产精品成人综合色在线婷婷| 亚洲国产精品日韩| 久久国产欧美日韩精品| 久久狠狠一本精品综合网| 欧美午夜精品久久久| 99精品视频一区二区三区| 一区二区在线看| 欧美不卡高清| 亚洲国产精品激情在线观看| 亚洲高清一区二| 久久综合伊人77777尤物| 久久综合久久美利坚合众国| 国产一区二区黄色| 欧美在线视频免费| 亚洲精品一区二区三区婷婷月| 久久午夜激情| 亚洲电影在线| 日韩午夜三级在线| 欧美日韩国产美| 免费在线成人| 亚洲视频电影在线| 国产精品多人| 亚洲综合精品自拍| 久久超碰97中文字幕| 国产伊人精品| 欧美日韩视频一区二区三区| 日韩亚洲一区二区| 亚洲欧美精品在线观看| 国产精品视频免费观看www| 亚洲欧美在线x视频| 欧美激情影院|