• <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>
            posts - 183,  comments - 10,  trackbacks - 0

            來自于《算法:C 語言實(shí)現(xiàn)》
            1.

             1 // 快速查找算法
             2 
             3 #include <stdio.h>
             4 #define N 10000
             5 
             6 int main()
             7 {
             8     int i, p, q, t, id[N];
             9     for (i = 0; i < N; ++i)
            10     {
            11         id[i] = i;
            12     }
            13     while (scanf("%d %d"&p, &q) == 2)
            14     {
            15         if (id[p] == id[q])
            16         {
            17             continue;
            18         }
            19         for (t = id[p], i = 0; i < N; ++i)
            20         {
            21             if (id[i] == t)
            22             {
            23                 id[i] = id[q];
            24             }
            25         }
            26         printf(" %d %d\n", p, q);
            27     }
            28 }

            2.
             1 // 快速合并算法
             2 
             3 #include <stdio.h>
             4 #define N 10000
             5 
             6 int main()
             7 {
             8     int i, j, p, q, id[N];
             9     for (i = 0; i < N; ++i)
            10     {
            11         id[i] = i;
            12     }
            13     while (scanf("%d %d"&p, &q) == 2)
            14     {
            15         for (i = p; i != id[i]; i = id[i]);
            16         for (j = q; j != id[j]; j = id[j]);
            17         if (i == j)
            18         {
            19             continue;
            20         }
            21         id[i] = j;
            22         printf(" %d %d\n", p, q);
            23     }
            24 }

            3.
             1 // 加權(quán)快速合并算法
             2 
             3 #include <stdio.h>
             4 #define N 10000
             5 
             6 int main()
             7 {
             8     int i, j, p, q, id[N], sz[N];
             9     for (i = 0; i < N; ++i)
            10     {
            11         id[i] = i;
            12         sz[i] = 1;
            13     }
            14     while (scanf("%d %d"&p, &q) == 2)
            15     {
            16         for (i = p; i != id[i]; i = id[i]);
            17         for (j = q; j != id[j]; j = id[j]);
            18         if (i == j)
            19         {
            20             continue;
            21         }
            22         if (sz[i] < sz[j])
            23         {
            24             id[i] = j;
            25             sz[j] += sz[i];
            26         }
            27         else
            28         {
            29             id[j] = i;
            30             sz[i] += sz[j];
            31         }
            32         printf(" %d %d\n", p, q);
            33     }
            34 }

            4.
             1 // 帶有等分路徑壓縮的加權(quán)快速-合并算法
             2 
             3 #include <stdio.h>
             4 #define N 10000
             5 
             6 int main()
             7 {
             8     int i, j, p, q, id[N], sz[N];
             9     for (i = 0; i < N; ++i)
            10     {
            11         id[i] = i;
            12         sz[i] = 1;
            13     }
            14     while (scanf("%d %d"&p, &q) == 2)
            15     {
            16         for (i = p; i != id[i]; i = id[i])
            17         {
            18             id[i] = id[id[i]];
            19         }
            20         for (j = q; j != id[j]; j = id[j])
            21         {
            22             id[j] = id[id[j]];
            23         }
            24         if (i == j)
            25         {
            26             continue;
            27         }
            28         if (sz[i] < sz[j])
            29         {
            30             id[i] = j;
            31             sz[j] += sz[i];
            32         }
            33         else
            34         {
            35             id[j] = i;
            36             sz[i] += sz[j];
            37         }
            38         printf(" %d %d\n", p, q);
            39     }
            40 }

            posted on 2011-04-20 17:01 unixfy 閱讀(385) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            精品综合久久久久久888蜜芽| 久久综合视频网站| 久久人人爽人人爽人人片AV东京热| 久久国产亚洲高清观看| 一本久久a久久精品综合香蕉 | 91性高湖久久久久| .精品久久久麻豆国产精品| 99蜜桃臀久久久欧美精品网站| 三级三级久久三级久久| 一本久久精品一区二区| 久久笫一福利免费导航 | 久久一区二区三区99| 国产免费久久精品丫丫| 品成人欧美大片久久国产欧美...| 国产一区二区三精品久久久无广告 | 国产福利电影一区二区三区,免费久久久久久久精 | 久久久久久亚洲AV无码专区 | 亚洲国产日韩欧美久久| 久久久午夜精品| 久久久久久久人妻无码中文字幕爆| 久久久精品人妻一区二区三区蜜桃 | 久久99精品国产99久久| 亚洲国产精品无码久久98| 久久婷婷五月综合国产尤物app| 2021精品国产综合久久| 久久亚洲国产成人影院网站| 无码国内精品久久综合88| 亚洲国产精品无码久久久秋霞2| 久久久婷婷五月亚洲97号色 | 日韩久久久久久中文人妻| 91精品国产综合久久婷婷| 久久久无码精品亚洲日韩软件| 久久精品aⅴ无码中文字字幕不卡| 久久大香香蕉国产| 日韩亚洲国产综合久久久| 久久国产色AV免费看| 亚洲国产成人精品女人久久久| 麻豆一区二区99久久久久| 欧美午夜精品久久久久久浪潮| 久久精品成人免费网站| 久久国语露脸国产精品电影|