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

posts - 195,  comments - 30,  trackbacks - 0

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

1.問題定義

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

      假設現在有四個城市,0,1,2,3,他們之間的代價如圖一,可以存成二維表的形式

              image        image

                      圖一                                                                                               

        現在要從城市0出發,最后又回到0,期間1,2,3都必須并且只能經過一次,使代價最小。

2.動態規劃可行性

        設s, s1, s2, …, sp, s是從s出發的一條路徑長度最短的簡單回路,假設從s到下一個城市s1已經求出,則問題轉化為求從s1到s的最短路徑,顯然s1, s2, …, sp, s一定構成一條從s1到s的最短路徑,所以TSP問題是構成最優子結構性質的,用動態規劃來求解也是合理的。

3.推導動態規劃方程

        假設從頂點s出發,令d(i, V’)表示從頂點i出發經過V’(是一個點的集合)中各個頂點一次且僅一次,最后回到出發點s的最短路徑長度。

        推導:(分情況來討論)

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

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

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

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

        綜上所述,TSP問題的動態規劃方程就出來了:

         image

4.實例分析

     現在對問題定義中的例子來說明TSP的求解過程。(假設出發城市是 0城市)

     image

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

    ②d(0,{1,2,3})是不能一下子求出來的,那么他的值是怎么得出的呢?看上圖的第二層,第二層表明了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})同樣也不是一步就能求出來的,它們的解一樣需要有依賴,就比如說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})同樣需要這么求。

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

image

這張表里求得的。

     5.編程思路

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

image

        在程序中模擬填表的過程,主要要考慮到j這個參數的表示,它要代表一個集合,可以用二維數組來表示。

   6.源代碼

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

#include 
#include

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

    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])//實現V'-{k} 的下標檢索 

    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;  //相當于去掉k這個城市 
    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'為空時,給賦值, 
        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必須不在集合中,否則就屬于經過兩次,不符合題意 
            { 
                for(k = 0; k < 3; k++)//分別試探集合中的每一點,取最小值 
                { 
                    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++)//分別試探下一步為集合中的任何一點,取最小值 
    { 
        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;   //假設1000為無窮大 
    TSP(d,c,V,4); 
    printf("The least road is:%d/n",d[0][7]); 
}

posted on 2013-03-31 05:26 luis 閱讀(18778) 評論(0)  編輯 收藏 引用 所屬分類: 動態規劃
<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

文章分類

文章檔案

友情鏈接

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国内精品写真在线观看| 美女啪啪无遮挡免费久久网站| 国产精品v日韩精品| 久久久久九九视频| 午夜视频在线观看一区二区三区 | av成人福利| 亚洲人体1000| 亚洲欧洲精品一区| 136国产福利精品导航| 娇妻被交换粗又大又硬视频欧美| 国产欧美在线观看一区| 国产精品综合| 黄色成人免费网站| 亚洲第一中文字幕| 日韩视频在线观看免费| 亚洲视频免费观看| 日韩亚洲精品在线| 欧美噜噜久久久xxx| 美女黄毛**国产精品啪啪| 久久精品二区亚洲w码| 久久久久成人精品| 欧美激情久久久久久| 欧美视频二区| 国产伊人精品| 日韩一级精品视频在线观看| 亚洲少妇自拍| 久久久噜久噜久久综合| 亚洲国产精品黑人久久久| 美国十次成人| 亚洲高清一区二区三区| 一本久道久久综合狠狠爱| 亚洲免费婷婷| 久久视频精品在线| 巨胸喷奶水www久久久免费动漫| 欧美成在线观看| 国产精品日本欧美一区二区三区| 嫩草影视亚洲| 国产精品入口麻豆原神| 亚洲国产精品久久久久婷婷老年 | 欧美影院午夜播放| 欧美大片免费久久精品三p | 欧美国产日韩a欧美在线观看| 欧美性开放视频| 一色屋精品亚洲香蕉网站| 欧美顶级少妇做爰| 欧美午夜剧场| 91久久视频| 久久野战av| 一区二区日韩精品| 久久婷婷久久| 国产一区二区精品在线观看| 亚洲精品中文字幕女同| 久久久999精品| 国产精品99久久久久久宅男| 久久视频这里只有精品| 免费成人av| 国产精一区二区三区| 亚洲三级视频| 欧美成人亚洲成人| 91久久国产自产拍夜夜嗨| 性欧美1819sex性高清| 欧美特黄a级高清免费大片a级| 在线日韩av片| 久久精品国产成人| 亚洲视频综合| 一本色道久久综合亚洲二区三区| 久久久久久久激情视频| 国产精品视频内| 亚洲欧美日韩中文视频| 亚洲精品国产精品乱码不99| 午夜精品久久久久久久蜜桃app| 欧美精品色一区二区三区| 亚洲大片免费看| 玖玖玖国产精品| 欧美在线首页| 一区二区三区自拍| 久久久久欧美精品| 亚洲欧美激情视频在线观看一区二区三区| 欧美精品v国产精品v日韩精品| 亚洲高清影视| 亚洲电影自拍| 欧美日韩一区三区| 在线不卡中文字幕| 蜜桃av一区二区| 免费看成人av| 99re6这里只有精品视频在线观看| 欧美在线日韩| 欧美一区二区三区四区在线观看地址| 国产欧美三级| 欧美一区二区三区日韩| 亚洲一区二区成人在线观看| 欧美午夜一区| 久久午夜精品一区二区| 鲁大师影院一区二区三区| 亚洲私人黄色宅男| 欧美主播一区二区三区美女 久久精品人| 黄色精品免费| 亚洲午夜久久久| 亚洲在线一区二区三区| 精品动漫3d一区二区三区免费版| 亚洲精品一区二区三区婷婷月| 国产精品永久免费| 亚洲国产成人午夜在线一区| 国产精品久久久久毛片大屁完整版 | 亚洲精品乱码久久久久久蜜桃91| 国产精品99久久久久久久久| 亚洲成色www8888| 亚洲综合精品自拍| 一本久久青青| 欧美v国产在线一区二区三区| 欧美一级电影久久| 欧美日韩中文另类| 亚洲国产精品va在线观看黑人 | 女女同性精品视频| 久久免费视频网| 国产精品久久久久秋霞鲁丝| 亚洲黄网站在线观看| 亚洲福利视频网站| 久久久久久免费| 国产精品v片在线观看不卡| 亚洲国产精品久久久久婷婷884 | 免费不卡在线观看av| 欧美一区永久视频免费观看| 欧美日韩视频| 亚洲欧洲美洲综合色网| 亚洲黄色免费| 久久亚洲私人国产精品va媚药| 久久精品一区二区| 国产欧美欧洲在线观看| 亚洲主播在线| 欧美一区二区三区四区视频 | 欧美成人精品不卡视频在线观看| 久久麻豆一区二区| 黄色精品一区| 久久午夜精品| 免费看的黄色欧美网站| 国产一区二区三区日韩欧美| 午夜在线播放视频欧美| 久久精品日韩欧美| 国精品一区二区三区| 欧美在线视频网站| 另类图片综合电影| 在线观看亚洲精品视频| 久久天天躁狠狠躁夜夜爽蜜月| 欧美国产精品人人做人人爱| 亚洲国产精品美女| 欧美精品亚洲| 一区二区三区成人精品| 欧美国产国产综合| 亚洲精品国产欧美| 亚洲综合日韩在线| 国产伦精品一区二区三区视频黑人 | 久久综合一区二区| 亚洲国产精品久久精品怡红院| 欧美成人精品激情在线观看| 日韩视频免费在线| 欧美专区日韩专区| 亚洲国产成人av| 欧美色图麻豆| 先锋影音久久| 欧美激情二区三区| 亚洲尤物在线| 在线观看三级视频欧美| 欧美精品一卡二卡| 欧美一区二区视频网站| 欧美国产成人精品| 亚洲欧美国产制服动漫| 狠狠色噜噜狠狠色综合久 | 在线播放精品| 欧美三级午夜理伦三级中视频| 亚洲在线成人| 亚洲成人在线网站| 欧美在线www| 亚洲伦理久久| 国产午夜精品一区二区三区欧美| 久久综合伊人| 亚洲欧美在线x视频| 亚洲国产精品福利| 国产精品视频成人| 欧美www在线| 亚洲女女女同性video| 欧美高清不卡| 久久精品国产亚洲aⅴ| 夜夜嗨av一区二区三区| 精品成人在线观看| 国产乱子伦一区二区三区国色天香 | 欧美精品午夜| 久久琪琪电影院| 亚洲综合精品一区二区| 亚洲激情啪啪| 欧美国产激情| 久久亚洲精品视频| 欧美一区午夜视频在线观看| 亚洲视频专区在线| 亚洲区一区二| 樱桃成人精品视频在线播放| 国产精品一区二区久久| 国产精品99一区| 欧美日韩成人综合天天影院| 麻豆国产va免费精品高清在线|