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

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精品欧美一区二区蜜桃免费| 亚洲成色www久久网站| 久久久精品五月天| 欧美一级片一区| 久久精品国内一区二区三区| 久久久精品午夜少妇| 毛片av中文字幕一区二区| 欧美国产日韩精品免费观看| 欧美精品九九| 国产精品久久久久久亚洲调教| 欧美丝袜一区二区| 国产午夜精品一区理论片飘花 | 欧美一区二区三区成人| 久久电影一区| 亚洲国产成人久久| 一本大道av伊人久久综合| 亚洲欧美日韩国产一区二区| 久久久www成人免费毛片麻豆| 欧美大成色www永久网站婷| 国产精品久久久久久久久动漫| 国产免费观看久久| 亚洲精品综合精品自拍| 欧美主播一区二区三区| 亚洲国产精品嫩草影院| 性欧美超级视频| 欧美激情一区三区| 国产揄拍国内精品对白| 一区二区三区欧美视频| 欧美96在线丨欧| 亚洲一区国产精品| 欧美激情一区二区三区成人| 国产日韩欧美精品一区| 一本色道久久88综合日韩精品 | 蜜桃av一区| 国产欧美精品va在线观看| 亚洲人成亚洲人成在线观看图片 | 亚洲人成77777在线观看网| 亚洲欧美日本国产专区一区| 欧美激情视频在线免费观看 欧美视频免费一 | 欧美日韩亚洲一区二区三区在线观看 | 亚洲国产专区| 亚洲欧美久久| 欧美日韩视频在线观看一区二区三区| 国产精品亚洲精品| 一级成人国产| 欧美国产三区| 久久久精品一区| 国产日韩在线看| 在线亚洲高清视频| 亚洲大片精品永久免费| 久久久99免费视频| 国内精品久久久久久久97牛牛| 欧美一区午夜精品| 亚洲色无码播放| 欧美性感一类影片在线播放| 夜夜精品视频| 亚洲免费观看视频| 欧美日韩视频在线第一区| 亚洲伦理自拍| 最新高清无码专区| 欧美激情精品| 9i看片成人免费高清| 亚洲国产成人久久综合| 欧美国产欧美亚洲国产日韩mv天天看完整| 在线观看成人av电影| 免费视频久久| 欧美国产日韩一区| 在线综合亚洲欧美在线视频| 一区二区三区欧美日韩| 国产精品毛片高清在线完整版| 亚洲综合电影| 性亚洲最疯狂xxxx高清| 韩国精品主播一区二区在线观看| 久久久久久欧美| 玖玖视频精品| 妖精视频成人观看www| 亚洲人成人一区二区在线观看| 欧美电影在线| 午夜精彩视频在线观看不卡 | 亚洲欧美在线免费| 国产一区二区三区高清播放| 奶水喷射视频一区| 欧美极品影院| 亚洲欧美精品suv| 欧美在线电影| 亚洲品质自拍| 亚洲一区二区三区视频| 国内揄拍国内精品久久| 亚洲电影免费观看高清| 国产精品久久久久国产a级| 久久九九精品| 欧美日韩爆操| 毛片基地黄久久久久久天堂| 欧美日本国产精品| 亚洲免费观看在线观看| 久久久美女艺术照精彩视频福利播放| 怡红院av一区二区三区| 亚洲日本中文字幕| 国产亚洲欧洲997久久综合| 欧美国产一区二区| 国产精品入口日韩视频大尺度| 久久最新视频| 国产精品欧美日韩一区二区| 欧美国产免费| 国产日韩在线看片| 99精品免费| 亚洲激情欧美激情| 欧美在线播放视频| 亚洲一区免费网站| 欧美高清在线视频| 久久久夜精品| 国产精品久久国产三级国电话系列 | 欧美中文日韩| 亚洲视频在线一区| 久久综合九色综合欧美狠狠| 亚洲综合日本| 欧美激情一区二区三区在线视频 | 国产综合18久久久久久| 亚洲美女av网站| 亚洲福利av| 欧美在线首页| 先锋影音国产精品| 欧美日韩1区2区| 亚洲电影免费观看高清完整版| 韩国精品久久久999| 亚洲一区黄色| 亚洲女同精品视频| 国产精品国色综合久久| 亚洲美女黄网| 99国产精品久久久久久久成人热| 老鸭窝91久久精品色噜噜导演| 久久久久欧美精品| 国产小视频国产精品| 午夜精品久久99蜜桃的功能介绍| 亚洲免费人成在线视频观看| 欧美日韩一区成人| 亚洲天堂av在线免费观看| 一区二区三区免费观看| 国产精品va在线播放我和闺蜜| 中文av一区二区| 亚洲欧美激情视频| 国产日韩一区二区| 久久久久女教师免费一区| 老司机免费视频久久| 亚洲高清资源综合久久精品| 免费91麻豆精品国产自产在线观看| 欧美a级在线| 亚洲欧洲日夜超级视频| 欧美日本一区二区高清播放视频| 亚洲国产成人在线视频| 91久久久亚洲精品| 欧美另类videos死尸| 中文在线一区| 西瓜成人精品人成网站| 亚洲丰满在线| 亚洲免费电影在线| 国产精品毛片在线看| 欧美一级视频一区二区| 六月婷婷一区| 夜夜嗨av一区二区三区网页| 国产精品第十页| 午夜精品福利电影| 欧美激情影院| 欧美亚洲视频在线观看| 影音先锋久久精品| 欧美激情视频给我| 亚洲欧美日韩在线一区| 欧美xx69| 午夜精品理论片| 亚洲免费中文| 欧美国产专区| 亚洲激情视频| 久久久久一区| 免费看精品久久片| 亚洲国产精品一区二区久| 亚洲欧美日本另类| 欧美电影电视剧在线观看| 亚洲国产另类精品专区| 一本色道久久综合| 国产一区二区三区无遮挡| 欧美成人一区二区在线| 亚洲天堂男人| 欧美激情第1页| 亚欧成人在线| 亚洲剧情一区二区| 国产伊人精品| 国产精品高清一区二区三区| 久久综合狠狠综合久久综青草 | 欧美视频免费看| 久久精品视频网| 亚洲综合精品| 日韩视频免费大全中文字幕| 欧美成人国产一区二区| 久久福利毛片| 亚洲欧美日韩中文视频| 一本在线高清不卡dvd | 亚洲人成网站影音先锋播放| 国产一区二区三区四区在线观看|