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

posts - 195,  comments - 30,  trackbacks - 0

原文地址: http://blog.csdn.net/gfaiswl/article/details/4749713

1.問題定義

      TSP問題(旅行商問題)是指旅行家要旅行n個(gè)城市,要求各個(gè)城市經(jīng)歷且僅經(jīng)歷一次然后回到出發(fā)城市,并要求所走的路程最短。

      假設(shè)現(xiàn)在有四個(gè)城市,0,1,2,3,他們之間的代價(jià)如圖一,可以存成二維表的形式

              image        image

                      圖一                                                                                               

        現(xiàn)在要從城市0出發(fā),最后又回到0,期間1,2,3都必須并且只能經(jīng)過(guò)一次,使代價(jià)最小。

2.動(dòng)態(tài)規(guī)劃可行性

        設(shè)s, s1, s2, …, sp, s是從s出發(fā)的一條路徑長(zhǎng)度最短的簡(jiǎn)單回路,假設(shè)從s到下一個(gè)城市s1已經(jīng)求出,則問題轉(zhuǎn)化為求從s1到s的最短路徑,顯然s1, s2, …, sp, s一定構(gòu)成一條從s1到s的最短路徑,所以TSP問題是構(gòu)成最優(yōu)子結(jié)構(gòu)性質(zhì)的,用動(dòng)態(tài)規(guī)劃來(lái)求解也是合理的。

3.推導(dǎo)動(dòng)態(tài)規(guī)劃方程

        假設(shè)從頂點(diǎn)s出發(fā),令d(i, V’)表示從頂點(diǎn)i出發(fā)經(jīng)過(guò)V’(是一個(gè)點(diǎn)的集合)中各個(gè)頂點(diǎn)一次且僅一次,最后回到出發(fā)點(diǎn)s的最短路徑長(zhǎng)度。

        推導(dǎo):(分情況來(lái)討論)

        ①當(dāng)V’為空集,那么d(i, V’),表示從i不經(jīng)過(guò)任何點(diǎn)就回到s了,如上圖的 城市3->城市0(0為起點(diǎn)城市)。此時(shí)d(i, V’)=Cis(就是 城市i 到 城市s 的距離)、

        ②如果V’不為空,那么就是對(duì)子問題的最優(yōu)求解。你必須在V’這個(gè)城市集合中,嘗試每一個(gè),并求出最優(yōu)解。

           d(i, V’)=min{Cik +  d(k, V’-{k})}

           注:Cik表示你選擇的城市和城市i的距離,d(k, V’-{k})是一個(gè)子問題。

        綜上所述,TSP問題的動(dòng)態(tài)規(guī)劃方程就出來(lái)了:

         image

4.實(shí)例分析

     現(xiàn)在對(duì)問題定義中的例子來(lái)說(shuō)明TSP的求解過(guò)程。(假設(shè)出發(fā)城市是 0城市)

     image

    ①我們要求的最終結(jié)果是d(0,{1,2,3}),它表示,從城市0開始,經(jīng)過(guò){1,2,3}之中的城市并且只有一次,求出最短路徑.

    ②d(0,{1,2,3})是不能一下子求出來(lái)的,那么他的值是怎么得出的呢?看上圖的第二層,第二層表明了d(0,{1,2,3})所需依賴的值。那么得出:

       d(0,{1,2,3})=min  {

                                    C01+d(1,{2,3})

                                    C02+d{2,{1,3}}

                                    C03+d{3,{1,2}}

                                  }

     ③d(1,{2,3}),d(2,{1,3}),d(3,{1,2})同樣也不是一步就能求出來(lái)的,它們的解一樣需要有依賴,就比如說(shuō)d(1,{2,3})

       d(1,{2,3})=min{

                              C12+d(2,{3})                             

                              C13+d(3,{2})

                              }

       d(2,{1,3}),d(3,{1,2})同樣需要這么求。

    ④按照上面的思路,只有最后一層的,當(dāng)當(dāng)V’為空集時(shí),Cis的值才可以求,它的值是直接從

image

這張表里求得的。

     5.編程思路

        將d(i, V’)轉(zhuǎn)換成二維表,d[i][j]

image

        在程序中模擬填表的過(guò)程,主要要考慮到j(luò)這個(gè)參數(shù)的表示,它要代表一個(gè)集合,可以用二維數(shù)組來(lái)表示。

   6.源代碼

注:由于本人水平有限,并且主要在這里是體現(xiàn)思路,所以程序并不是很完善,代碼質(zhì)量也不高,很地方可以寫得通用一些,所以這里只是提供一個(gè)參考,程序的進(jìn)一步完善,由讀者自由發(fā)揮。

#include 
#include

int IsIncluded(int x,int array[3])//x是否包含在數(shù)組中 

    if((array[0] != x) && (array[1] != x) && (array[2] != x)) 
        return 0; 
    return 1; 

int Left(int k,int array[3],int V[8][3])//實(shí)現(xiàn)V'-{k} 的下標(biāo)檢索 

    int i = 0,index = 0,array_0_count = 0,array_1_count = 0,array_2_count = 0,array_3_count = 0; 
    int V_0_count = 0,V_1_count = 0,V_2_count = 0,V_3_count = 0; 
    int temp[3]; 
    for(i = 0; i < 3; i++) 
        temp[i] = array[i]; 
    for(i = 0; i < 3; i++) 
        if(temp[i] == k) 
            temp[i] = 0;  //相當(dāng)于去掉k這個(gè)城市 
    for(i = 0; i < 3; i++) 
    { 
        if(temp[i] == 0) 
            array_0_count++; 
        else if(temp[i] == 1) 
            array_1_count++; 
        else if(temp[i] == 2) 
            array_2_count++; 
        else 
            array_3_count++; 
    } 
    for(index = 0; index < 8; index++) 
    { 
        for(i=0; i < 3; i++) 
        { 
            if(V[index][i] == 0) 
                V_0_count++; 
            else if(V[index][i] == 1) 
                V_1_count++; 
            else if(V[index][i] == 2) 
                V_2_count++; 
            else 
                V_3_count++; 
        } 
        if((array_0_count == V_0_count) && (array_1_count == V_1_count) 
            && (array_2_count == V_2_count) && (array_3_count == V_3_count)) 
            return index; 
        V_0_count = 0; 
        V_1_count = 0; 
        V_2_count = 0; 
        V_3_count = 0; 
    } 
    return 0; 
}

void TSP(int d[4][8],int c[4][4],int V[8][3],int n) 

    int i = 0,j = 0,k = 0;

    for(i = 1; i < n; i++)//V'為空時(shí),給賦值, 
        d[i][0] = c[i][0];

    for(j = 1; j < 7; j++)//按列遍歷不同集合,{1},{2},{3},{1,2},{1,3}..... 
    { 
        for(i = 1; i < n; i++)//遍歷城市1,2,3 
        { 
            if( !IsIncluded(i,V[j]) )//i必須不在集合中,否則就屬于經(jīng)過(guò)兩次,不符合題意 
            { 
                for(k = 0; k < 3; k++)//分別試探集合中的每一點(diǎn),取最小值 
                { 
                    if((V[j][k] != 0) && ((c[i][V[j][k]] + d[V[j][k]][Left(V[j][k],V[j],V)]) < d[i][j])) 
                        d[i][j] = c[i][V[j][k]] + d[V[j][k]][Left(V[j][k],V[j],V)]; 
                } 
            } 
        }//end of     for(i = 1; i < n; i++)//遍歷城市1,2,3 
    }//end of for(j = 1; j < ((int)pow(2,n)-1); j++) 
    for(k = 0; k < 3; k++)//分別試探下一步為集合中的任何一點(diǎn),取最小值 
    { 
        if((V[7][k] != 0) && (c[0][V[7][k]] + d[V[7][k]][Left(V[7][k],V[7],V)]) < d[0][7]) 
            d[0][7] = c[0][V[7][k]] + d[V[7][k]][Left(V[7][k],V[7],V)]; 
    } 

void main() 

    int V[8][3]= 
    { 
        0,0,0, 
        0,0,1, 
        0,0,2, 
        0,0,3, 
        0,1,2, 
        0,1,3, 
        0,2,3, 
        1,2,3 
    }; 
    int c[4][4]= 
    { 
        0,3,6,7, 
        5,0,2,3, 
        6,4,0,2, 
        3,7,5,0 
    }; 
    int d[4][8]={0},i=0,j=0;

    for(i=0; i<4; i++) 
        for(j=0; j<8; j++) 
            d[i][j]=1000;   //假設(shè)1000為無(wú)窮大 
    TSP(d,c,V,4); 
    printf("The least road is:%d/n",d[0][7]); 
}

posted on 2013-03-31 05:26 luis 閱讀(18765) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 動(dòng)態(tài)規(guī)劃
<2013年3月>
242526272812
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

文章分類

文章檔案

友情鏈接

搜索

  •  

最新評(píng)論

閱讀排行榜

評(pí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>
            欧美激情麻豆| 一区二区电影免费在线观看| 亚洲免费小视频| 亚洲韩国日本中文字幕| 亚洲国产另类久久精品| 国产亚洲va综合人人澡精品| 亚洲裸体俱乐部裸体舞表演av| 性娇小13――14欧美| 日韩天堂av| 99成人在线| 性欧美1819sex性高清| 久久免费精品日本久久中文字幕| 美国成人直播| 91久久极品少妇xxxxⅹ软件| 99精品久久久| 欧美亚洲综合另类| 欧美福利视频在线观看| 欧美三级午夜理伦三级中文幕| 欧美午夜寂寞影院| 国产日韩欧美黄色| 亚洲第一色中文字幕| 一本色道久久综合一区| 久久精彩免费视频| 亚洲狠狠丁香婷婷综合久久久| 亚洲一级特黄| 欧美肥婆bbw| 国产视频一区欧美| a91a精品视频在线观看| 久久美女性网| 亚洲视频综合在线| 欧美—级在线免费片| 激情五月***国产精品| 亚洲在线免费| 亚洲精品一区二| 欧美综合激情网| 欧美性生交xxxxx久久久| 影音先锋成人资源站| 亚洲免费网址| 亚洲激情电影中文字幕| 久久精品一本| 国产美女精品人人做人人爽| 99精品国产在热久久婷婷| 久久米奇亚洲| 亚洲欧美影院| 久久久久国产精品一区| 日韩一级在线| 欧美成人一区在线| 国内精品免费在线观看| 亚洲欧美日韩精品| 亚洲免费成人av电影| 欧美freesex交免费视频| 国产一区二区三区久久精品| 午夜国产欧美理论在线播放| 一区二区三区免费网站| 欧美日产一区二区三区在线观看| 国内精品久久久久久久影视蜜臀| 午夜精彩国产免费不卡不顿大片| 亚洲人成在线播放| 欧美成人午夜剧场免费观看| 亚洲承认在线| 欧美国产综合视频| 久久久亚洲精品一区二区三区 | 国产亚洲欧美日韩精品| 午夜老司机精品| 亚洲在线视频免费观看| 国产精品欧美日韩一区| 午夜视频在线观看一区二区| 亚洲欧美日韩国产一区| 国产日韩一区二区三区在线播放| 久久福利影视| 噜噜噜噜噜久久久久久91 | 欧美xx69| 亚洲国产日韩在线| 亚洲韩国青草视频| 欧美日韩国产精品专区| 亚洲一区二区三区免费视频| 亚洲午夜日本在线观看| 国产欧美va欧美va香蕉在| 久久国产婷婷国产香蕉| 一区二区三区视频在线播放| 国产精品乱码一区二三区小蝌蚪| 性亚洲最疯狂xxxx高清| 欧美在现视频| 亚洲激情在线观看视频免费| 91久久极品少妇xxxxⅹ软件| 欧美日韩精品是欧美日韩精品| 亚洲一区网站| 久久人人看视频| 一区二区三区视频在线| 99在线精品视频| 国产亚洲女人久久久久毛片| 亚洲国产欧美日韩| 国产女主播一区二区| 欧美承认网站| 国产精品久久久久久久久久三级 | 亚洲视频精选| 亚洲国内精品在线| 欧美日韩99| 欧美午夜精品伦理| 亚洲日本va午夜在线电影| 亚洲一区二区三区中文字幕| 国内精品视频一区| 免费成人小视频| 美女主播一区| 亚洲精品一区在线| 午夜精品久久久久久久| 韩国av一区二区三区| 亚洲片国产一区一级在线观看| 欧美日韩综合精品| 久久伊人精品天天| 欧美三区在线观看| 免费亚洲网站| 国产精品大片免费观看| 久久久久国产一区二区三区| 欧美国产另类| 久久九九热re6这里有精品 | 国产欧美一级| 欧美黑人多人双交| 国产精品视频yy9099| 欧美成人资源网| 国产精品自在欧美一区| 亚洲韩国一区二区三区| 狠狠色综合网站久久久久久久| 中文在线不卡| 中文有码久久| 欧美成人亚洲成人| 欧美成人免费小视频| 国产亚洲亚洲| 欧美亚洲综合在线| 久久精品青青大伊人av| 国产精品www| 一区二区三区成人精品| 正在播放欧美视频| 欧美人与性动交α欧美精品济南到| 美女脱光内衣内裤视频久久网站| 国产酒店精品激情| 亚洲欧美区自拍先锋| 亚洲欧美日韩在线高清直播| 欧美性猛交99久久久久99按摩| 91久久黄色| 日韩一级不卡| 欧美人成网站| 亚洲九九精品| 一个色综合导航| 欧美日韩在线三级| 一区二区欧美亚洲| 亚洲欧美国产精品va在线观看| 欧美午夜在线一二页| 一本色道久久| 亚洲欧美欧美一区二区三区| 欧美视频精品一区| 亚洲综合首页| 久久久久免费观看| 亚洲成人在线观看视频| 久久夜色精品国产噜噜av| 亚洲第一黄色| 亚洲精品一区二区在线| 蜜桃av噜噜一区| 国产亚洲欧洲997久久综合| 久久精品动漫| 亚洲电影在线| 亚洲在线观看免费| 国产欧美日韩在线| 久久久久综合一区二区三区| 亚洲电影av| 亚洲欧美国产va在线影院| 国产偷国产偷亚洲高清97cao| 久久99伊人| 亚洲国产精品激情在线观看| 99亚洲视频| 国产综合色产在线精品| 男人天堂欧美日韩| 欧美日韩在线另类| 亚洲男人av电影| 亚洲承认在线| 欧美亚洲日本一区| 亚洲国产精品一区二区第一页| 欧美日韩国产精品一区| 午夜精品久久久久久 | 国产欧美一区二区精品性| 欧美有码在线观看视频| 欧美岛国激情| 亚洲欧美中文日韩v在线观看| 加勒比av一区二区| 欧美日韩国产综合一区二区| 午夜精品久久久久久久男人的天堂 | 可以看av的网站久久看| aa国产精品| 激情综合网址| 国产精品久久久久久久久久久久久久 | 欧美风情在线| 99国产一区二区三精品乱码| 国产精品专区h在线观看| 裸体一区二区| 午夜精品久久久久久久99水蜜桃 | 男女视频一区二区| 午夜久久久久久久久久一区二区| 亚洲黄色在线看| 国产亚洲欧美激情| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 |