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

CSU OJ - 1219: 建食堂 (所有結(jié)點間的最短路徑)

鏈接:http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1219

這個題
就是求出所有結(jié)點的距離之后,再找出某個結(jié)點,該結(jié)點離其它結(jié)點的最大距離是所有結(jié)點中是最小的...
解法1:深搜出所有結(jié)點間的距離,但是會超時,即使深搜的過程使用中記憶化搜索(就是用2維數(shù)組保存已經(jīng)搜出的答案,如果后面的搜索需要用到直接使用即可)...
解法2:Floyd算法,3重循環(huán)直接找出所有結(jié)點之間的最短距離
解法3:對每一個結(jié)點應(yīng)用一次迪杰斯特拉算法,找出所有結(jié)點與其它結(jié)點間的最短距離...

解法2:
#include <stdio.h>
#include <string.h>
#define MAX  (100 + 10)
#define INF (1000000 + 10)
int nN, nM;
int nDis[MAX][MAX];
void SearchAll()
{
    for (int k = 0; k < nN; ++k)
    {
        for (int i = 0; i < nN; ++i)
        {   
            for (int j = 0; j < nN; ++j)
            {
                if (nDis[i][k] + nDis[k][j] < nDis[i][j])
                {
                    nDis[i][j] = nDis[j][i] = nDis[i][k] + nDis[k][j];
                }
            }
        }
    }
}
int main()
{
    while (scanf("%d%d", &nN, &nM) == 2)
    {
        for (int i = 0; i < nN; ++i)
        {
            for (int j = 0; j < nN; ++j)
            {
                if (i == j)
                {
                    nDis[i][j] = 0;
                }
                else
                {
                    nDis[i][j] = INF;
                }
            }
        }
        while (nM--)
        {
            int nX, nY, nK;
            scanf("%d%d%d", &nX, &nY, &nK);
            nDis[nX][nY] = nDis[nY][nX] = nK;
        }
        SearchAll();
        bool bOk = false;
        int nMin = 1 << 30;
        
        for (int i = 0; i < nN; ++i)
        {
            int nTemp = 0;
            int j = 0;
            for ( ; j < nN; ++j)
            {
                if (i == j) continue;
                if (nDis[i][j] == INF)
                {
                    break;
                }
                else
                {
                    if (nDis[i][j] > nTemp)
                    {
                        nTemp = nDis[i][j];
                    }
                }
            }
            if (j == nN)
            {
                bOk = true;
                if (nTemp < nMin)
                {
                    nMin = nTemp;
                }
            }
        }
        
        if (bOk)
        {
            printf("%d\n", nMin);
        }
        else
        {
            printf("Can not\n");
        }
    }
    return 0;
}

關(guān)于Floyd算法,可以這樣理解...比如剛開始只取2個結(jié)點i,j,它們的距離一定是dis(i,j),但是還有其它結(jié)點,需要把其它結(jié)點也慢慢加進來,所以最外層關(guān)于k的循環(huán)意思就是從0至nN-1,把所有其它結(jié)點加進來,比如加入0號結(jié)點后,距離dis(i,0)+dis(0,j)可能會比dis(i,j)小,如果是這樣就更新dis(i,j),然后后面加入1號結(jié)點的時候,實際上是在已經(jīng)加入0號結(jié)點的基礎(chǔ)上進行的處理了,效果變成dis(i,0,1,j),可能是最小的,而且中間的0,1也可能是不存在的,當然是在dis(i,j)原本就是最小的情況下...
這個算法可以用下面這個圖片描述...


解法3:
#include <stdio.h>
#include <string.h>
#define MAX  (100 + 10)
#define INF (1000000 + 10)
int nN, nM;
int nDis[MAX][MAX];
void Search(int nSource)
{
    bool bVisit[MAX];
    memset(bVisit, false, sizeof(bVisit));
    bVisit[nSource] = true;
    for (int i = 0; i < nN - 1; ++i)
    {
        int nMin = INF;
        int nMinPos = 0;
        for (int j = 0; j < nN; ++j)
        {
            if (!bVisit[j] && nDis[nSource][j] < nMin)
            {
                nMin = nDis[nSource][j];
                nMinPos = j;
            }
        }
        if (bVisit[nMinPos] == false)
        {
            bVisit[nMinPos] = true;
            for (int j = 0; j < nN; ++j)
            {
                if (nDis[nSource][nMinPos] + nDis[nMinPos][j] < nDis[nSource][j])
                {
                    nDis[nSource][j] = nDis[nSource][nMinPos] + nDis[nMinPos][j];
                }
            }
        }
    }
}
void SearchAll()
{
    for (int k = 0; k < nN; ++k)
    {
        Search(k);
    }
}
int main()
{
    while (scanf("%d%d", &nN, &nM) == 2)
    {
        for (int i = 0; i < nN; ++i)
        {
            for (int j = 0; j < nN; ++j)
            {
                if (i == j)
                {
                    nDis[i][j] = 0;
                }
                else
                {
                    nDis[i][j] = INF;
                }
            }
        }
        while (nM--)
        {
            int nX, nY, nK;
            scanf("%d%d%d", &nX, &nY, &nK);
            nDis[nX][nY] = nDis[nY][nX] = nK;
        }
        SearchAll();
        bool bOk = false;
        int nMin = 1 << 30;
        for (int i = 0; i < nN; ++i)
        {
            int nTemp = 0;
            int j = 0;
            for ( ; j < nN; ++j)
            {
                if (i == j) continue;
                if (nDis[i][j] == INF)
                {
                    break;
                }
                else
                {
                    if (nDis[i][j] > nTemp)
                    {
                        nTemp = nDis[i][j];
                    }
                }
            }
            if (j == nN)
            {
                bOk = true;
                if (nTemp < nMin)
                {
                    nMin = nTemp;
                }
            }
        }
        if (bOk)
        {
            printf("%d\n", nMin);
        }
        else
        {
            printf("Can not\n");
        }
    }
    return 0;
}
迪杰斯特拉算法的核心思想是維護一個源點頂點集合,任何最短路徑一定是從這個頂點集合發(fā)出的...
初始化時,這個集合就是源點...
我們從該其它結(jié)點中選出一個結(jié)點,該結(jié)點到源點的距離最小...
顯然,這個距離就是源點到該結(jié)點的最短距離了,我們已經(jīng)找到了答案的一部分了...然后,我們就把該結(jié)點加入前面所說的頂點集合...
現(xiàn)在頂點集合更新了,我們必須得更新距離了...由于新加入的結(jié)點可能發(fā)出邊使得原來源點到某些結(jié)點的距離更小,也就是我們的源點變大了,邊也變多了,所以我們的最短距離集合的值也必須變化了...
該算法一直循環(huán)nN-1次,直至所有的點都加入源點頂點集合...

posted on 2011-12-04 22:20 yx 閱讀(1256) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告 、圖論

<2012年4月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

導(dǎo)航

統(tǒng)計

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學(xué)

網(wǎng)友

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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在线观看| 欧美激情精品久久久久久变态| 欧美高清hd18日本| 国产精品一区二区视频| 99视频精品免费观看| 久热精品在线| 亚洲一区尤物| 欧美性大战久久久久| 亚洲人成免费| 黄色成人免费观看| 夜夜嗨av色综合久久久综合网| 久久精品日韩欧美| 99精品国产福利在线观看免费| 久久亚洲国产精品日日av夜夜| 国产精品视频第一区| 亚洲图片自拍偷拍| 亚洲国产欧美精品| 性欧美暴力猛交69hd| 国产精品jvid在线观看蜜臀| 亚洲三级电影全部在线观看高清| 久久精品一区| 欧美一区二区三区在线| 国产精品毛片| 欧美一区二区三区在线观看| 亚洲一区二区在线免费观看| 欧美日韩大片| 亚洲综合日韩| 亚洲视频一区二区免费在线观看| 欧美国产精品日韩| 99精品视频一区| 亚洲精品在线视频| 国产精品久久网站| 亚洲砖区区免费| 中日韩男男gay无套| 欧美特黄一区| 欧美尤物巨大精品爽| 久久精品国产精品亚洲综合| 国产深夜精品福利| 久久精品国产久精国产思思| 久久久久国色av免费观看性色| 一区在线影院| 亚洲欧洲精品一区| 国产精品日韩在线观看| 久久精品国产亚洲一区二区三区| 久久精品亚洲精品| 日韩手机在线导航| 午夜久久影院| 日韩一级精品| 销魂美女一区二区三区视频在线| 影音先锋日韩有码| 99re这里只有精品6| 国产欧亚日韩视频| 亚洲高清视频一区二区| 国产精品久久久久久一区二区三区| 卡通动漫国产精品| 国产精品第2页| 蜜桃久久精品一区二区| 国产精品v欧美精品v日韩| 美女在线一区二区| 欧美日韩在线高清| 免费在线欧美黄色| 国产精品欧美一区喷水| 免费亚洲婷婷| 国产精品一二三四| 亚洲国产一区二区精品专区| 国产欧美视频一区二区| 亚洲精品欧洲精品| 一色屋精品视频在线观看网站| 正在播放亚洲一区| 亚洲人人精品| 久久精品亚洲| 久久精品亚洲| 国产有码一区二区| 国产精品久久久久久久久久免费 | 一本色道久久加勒比精品| 国产目拍亚洲精品99久久精品| 免费在线成人| 国产日韩在线一区二区三区| 欧美国产精品中文字幕| 国产精品成人一区二区艾草| 国产亚洲欧美一区二区| 欧美成人激情在线| 韩国成人精品a∨在线观看| 这里只有精品丝袜| 亚洲国产日韩欧美综合久久| 亚洲免费伊人电影在线观看av| 亚洲精品乱码久久久久久黑人 | 国产亚洲一区二区三区在线观看| 最近中文字幕日韩精品| 激情综合网激情| 欧美一级淫片aaaaaaa视频| 一本色道久久综合亚洲精品高清| 久久久久免费| 久久人人97超碰国产公开结果| 国产精品永久| 一区二区三区日韩欧美| 亚洲精品国产精品国产自| 久久裸体视频| 久久久国产91| 国产精品欧美久久久久无广告| 亚洲精品女人| 亚洲精品无人区| 麻豆av一区二区三区| 蜜桃av噜噜一区| 韩国一区二区在线观看| 久久久久久久综合色一本| 欧美在线视频免费| 亚洲春色另类小说| 狼人天天伊人久久| 欧美激情偷拍| 韩国av一区二区三区| 久热这里只精品99re8久| 美日韩丰满少妇在线观看| 亚洲福利视频二区| 欧美.www| 亚洲精品国产日韩| 亚洲欧美99| 国产日韩欧美另类| 久久国产精品亚洲va麻豆| 久久一区二区三区四区| 亚洲国产另类 国产精品国产免费| 欧美激情1区2区| 99精品久久久| 欧美在线观看视频一区二区三区| 国产欧美一区二区精品婷婷| 欧美一区亚洲| 亚洲国产日韩在线一区模特| 国产精品99久久久久久宅男| 国产精品一二三四| 久久影视精品| 亚洲精品日韩综合观看成人91 | 中文网丁香综合网| 午夜国产不卡在线观看视频| 亚洲三级免费电影| 欧美日韩在线播放三区| 亚洲视频久久| 欧美一区二区三区在| 亚洲国产欧美久久| 欧美精品激情blacked18| 亚洲永久免费| 免费久久99精品国产自在现线| 影音先锋日韩有码| 欧美日韩中国免费专区在线看| 午夜精品区一区二区三| 欧美国产一区二区| 亚洲欧美日韩一区在线观看| 亚洲激情av| 国产欧美一级| 欧美精品一区二区三区蜜臀| 欧美亚洲在线播放| 亚洲国产欧美一区二区三区久久| 欧美一区二区成人| 亚洲久久一区二区| 国产欧美日韩在线 | 欧美激情女人20p| 亚洲欧美日韩精品久久| 亚洲国产美国国产综合一区二区| 欧美一区二区三区精品电影| 亚洲三级性片| 国内精品福利| 欧美视频观看一区| 欧美好吊妞视频| 久久精品国产亚洲一区二区| 亚洲精品国精品久久99热| 久久婷婷蜜乳一本欲蜜臀| 亚洲女性裸体视频| 亚洲一区二区三区视频播放| 狠狠综合久久av一区二区老牛| 欧美激情aaaa| 蜜臀91精品一区二区三区| 午夜激情一区| 亚洲一区二区三区在线| 最新高清无码专区| 久久久久国产精品www| 在线视频欧美一区| 亚洲欧美日韩国产另类专区| 亚洲午夜av| 亚洲精品久久久蜜桃| 久久视频在线看| 午夜精品美女久久久久av福利| 亚洲欧美日韩区| 午夜精品久久久久99热蜜桃导演| 99国产欧美久久久精品| 最新日韩在线| 亚洲精选视频在线| 日韩一级精品| 国产精品99久久久久久人| 在线亚洲一区| 一区二区精品| 亚洲欧美激情精品一区二区| 一区二区日韩免费看| 日韩午夜中文字幕| 欧美成人dvd在线视频| 久久夜色精品国产欧美乱极品 | 国产精品国产三级国产| 欧美日韩国产在线一区| 久久精品30|