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

http://acm.hdu.edu.cn/showproblem.php?pid=2224
      貨郎問題(Traveling Salesman Problem,簡稱“TSP”)也叫貨郎擔(dān)問題,中國郵路問題,旅行商問題等,是計算機算法理論歷史上的經(jīng)典問題。在過去幾十年中,它成為許多重要算法思想的測試平臺,同時也促使一些新的理論領(lǐng)域的產(chǎn)生,比如多面體理論和復(fù)雜性理論。 貨郎問題:給定n個結(jié)點和任意一對結(jié)點{i,j}之間的距離為dist(i,j),要求找出一條閉合的回路,該回路經(jīng)過每個結(jié)點一次且僅一次,并且該回路的費用最小,這里的費用是指每段路徑的距離和。 貨郎問題求解其精確解是NP難的,并且求解任意常數(shù)因子近以度的解也是NP難的。若將問題限定在歐氏平面上,就成為歐氏平面上的貨郎問題,也叫歐幾里德旅行商問題(Eculid Traveling Salesman Problem)。但是,即使是歐氏平面上的貨郎問題也是NP難的。因此通常用來解決TSP問題的解法都是近似算法。其中第一個歐幾里德旅行商問題的多項式近似算法是Arora在1996年使用隨機平面分割和動態(tài)規(guī)劃方法給出的。

    J.L. Bentley 建議通過只考慮雙調(diào)旅程(bitonic tour)來簡化問題,這種旅程即為從最左點開始,嚴格地從左到右直至最右點,然后嚴格地從右到左直至出發(fā)點。事實上,存在確定的最優(yōu)雙調(diào)路線的O(n*n)時間的算法。

/**********************************************************************
*        Bitonic path (詳見《算法導(dǎo)論》 P217)                                                                                  
*        一個人從p1嚴格地增的走到pn,然后再嚴格遞減的回到p1;求總路徑的最小值;   
*        網(wǎng)上看到很多解題報告。。。看的我直冒汗     
*        只好自己看書,翻譯。。。                                                                  
*        對于1 <= i <= j <= n, 我們定義P(i, j)是一條包含了P1, P2, P3 …… Pj的途徑;                   
*        這條路徑可以分成2部分:遞減序列與遞增序列                                                                
*        起點是Pi(1 <= i <= j),拐點是P1,終點是Pj, P[i, j]為其最小值;                                     
*        狀態(tài)轉(zhuǎn)移方程為:                                                                                                                      
*        b[1,2] = |P1P2|,                                                                                                                               
*        i < j-1時, b[i,j] = b[i,j-1] + |Pj-1Pj|    點Pj-1在遞增序列中,                                                
*        i = j-1時, b[i,j] = min{ b[k,j-1] + |PkPj|, 1<= k < j-1 }  點Pj-1在遞減序列中                      
*        b[n,n] = b[n-1,n] + |Pn-1Pn|                                                                                                        
*********************************************************************
*/


#include 
<stdio.h>
#include 
<math.h>
#define INF 0x7fffffff
#define N 201
struct point{
    
double x, y;
}point[N];
int n;
double dis[N][N];

double distant(int i, int j)
{
    
return sqrt((point[i].x - point[j].x)*(point[i].x - point[j].x) + (point[i].y - point[j].y)*(point[i].y - point[j].y));
}

double dp()
{
    
int i, j, k;
    
double temp, b[N][N];

    b[
1][2= dis[1][2];
    
for (j=3; j<=n; j++)
    {
        
for (i=1; i<=j-2; i++)
            b[i][j] 
= b[i][j-1+ dis[j-1][j];

        b[j
-1][j] = INF;
        
for (k=1; k<=j-2; k++)
        {
            temp 
= b[k][j-1+ dis[k][j];
            
if (temp < b[j-1][j])
                b[j
-1][j] = temp;
        }
    }

    b[n][n] 
= b[n-1][n] + dis[n-1][n];

    
return b[n][n];
}

int main()
{
    
int i, j;
    
double ans;
    
while (scanf("%d"&n) > 0)
    {
        
for (i=1; i<=n; i++)
            scanf(
"%lf %lf"&point[i].x, &point[i].y);

        
for (j=2; j<=n; j++)
            
for (i=1; i<j; i++)
                dis[i][j] 
= distant(i,j); 

        ans 
= dp();

        printf(
"%.2lf\n", dp());
    }
}

 


 

posted on 2009-11-30 18:38 西風(fēng)蕭瑟 閱讀(7001) 評論(3)  編輯 收藏 引用 所屬分類: 動態(tài)規(guī)劃

評論:
# re: PKU2677,HDU2224 經(jīng)典DP之雙調(diào)旅行商(TSP) 2009-12-01 15:21 | 創(chuàng)意產(chǎn)品批發(fā)
佩服佩服。。。  回復(fù)  更多評論
  
# re: PKU2677,HDU2224 經(jīng)典DP之雙調(diào)旅行商(TSP) 2012-05-24 10:12 | aaa
* b[1,2] = |P1P2|,
* i = j-1時, b[i,j] = b[i,j-1] + |Pj-1Pj| 點Pj-1在遞增序列中,
* i < j-1時, b[i,j] = min{ b[k,j-1] + |PkPj|, 1<= k < j-1 } 點Pj-1在遞減序列中
* b[n,n] = b[n-1,n] + |Pn-1Pn|   回復(fù)  更多評論
  
# re: PKU2677,HDU2224 經(jīng)典DP之雙調(diào)旅行商(TSP) 2012-10-09 22:43 | keli
狀態(tài)轉(zhuǎn)移方程為:
* b[1,2] = |P1P2|,
* i < j-1時, b[i,j] = b[i,j-1] + |Pj-1Pj| 點Pj-1在遞增序列中,
* i = j-1時, b[i,j] = min{ b[k,j-1] + |PkPj|, 1<= k < j-1 } 點Pj-1在遞減序列中
* b[n,n] = b[n-1,n] + |Pn-1Pn|

==================
當(dāng)i = j-1時,狀態(tài)轉(zhuǎn)移方程應(yīng)該是:
b[i,j] = min{ b[j-1, k] + |PkPj|, 1 <= k < j-1 }吧,
雖然b[j-1, k] == b[k, j-1],但是我上面寫的才是合理的吧?  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲高清免费视频| 久久一区中文字幕| 久久国产88| 亚洲欧美国产视频| 欧美日韩成人一区| 亚洲国产日韩一区| 亚洲一级黄色| 欧美吻胸吃奶大尺度电影| 欧美 日韩 国产精品免费观看| 国产日韩欧美在线播放| 很黄很黄激情成人| 欧美一区二区精品| 国产精品视频免费一区| 中日韩午夜理伦电影免费| 亚洲综合色自拍一区| 欧美色道久久88综合亚洲精品| 亚洲日本中文| 亚洲一二三区在线| 夜夜精品视频| 亚洲欧美日韩国产成人| 久久九九全国免费精品观看| 久久人体大胆视频| 在线电影院国产精品| 久久久亚洲精品一区二区三区 | 亚洲电影下载| 国产亚洲观看| 久久精品国产69国产精品亚洲| 久久久噜噜噜久久人人看| 国内精品一区二区| 玖玖在线精品| 日韩天堂在线观看| 欧美在线视频不卡| 激情欧美一区二区| 欧美高清hd18日本| 一区二区三区精品视频| 欧美资源在线| 在线看欧美视频| 亚洲欧美国产va在线影院| 久久久精品一品道一区| 激情亚洲网站| 欧美日韩天堂| 欧美在线免费视屏| 欧美高清hd18日本| 亚洲免费小视频| 激情亚洲网站| 亚洲一区二区三区色| 国产麻豆成人精品| 美女网站久久| 亚洲图片欧美一区| 免费看黄裸体一级大秀欧美| 一区二区欧美在线观看| 国产农村妇女毛片精品久久莱园子| 久久激情五月激情| 亚洲美女视频| 老鸭窝亚洲一区二区三区| 一区二区电影免费观看| 国产亚洲一区在线| 欧美久久久久中文字幕| 欧美一级网站| 久久av红桃一区二区小说| 亚洲高清在线视频| 国产精品视频网| 欧美v日韩v国产v| 午夜欧美精品| 99在线观看免费视频精品观看| 久久午夜国产精品| 欧美精品久久久久久久久老牛影院| 免费中文日韩| 久久久噜噜噜久久中文字免| 正在播放欧美一区| 亚洲国产一区视频| 国产亚洲一区二区三区在线播放| 欧美日本国产精品| 老司机午夜精品视频在线观看| 亚洲免费在线| 99这里有精品| 亚洲精品美女久久7777777| 另类综合日韩欧美亚洲| 亚洲欧美综合v| 99国产精品自拍| 亚洲国产老妈| 久久免费视频在线观看| 亚洲精品在线视频观看| 欧美激情在线观看| 麻豆成人av| 久久―日本道色综合久久| 欧美在线国产精品| 亚洲欧美成aⅴ人在线观看| 欧美精品在线视频观看| 在线欧美不卡| 国产亚洲精品aa午夜观看| 国产精品h在线观看| 欧美精品一区二区三| 欧美成年网站| 美女日韩在线中文字幕| 久久久噜噜噜久久久| 久久成人免费网| 欧美永久精品| 欧美在线欧美在线| 欧美一区二区三区在线视频| 亚洲欧美一区二区三区在线| 久久久精品一区| 欧美一区日本一区韩国一区| 午夜精品在线| 欧美一区二区三区免费在线看 | 91久久精品一区| 精品动漫一区| 在线观看中文字幕不卡| 亚洲电影网站| 亚洲人成高清| 亚洲精品久久7777| 最近中文字幕日韩精品 | 久久综合九色综合欧美就去吻| 久久国产色av| 久久美女性网| 欧美大片在线观看一区| 亚洲第一中文字幕| 亚洲精品亚洲人成人网| 一区二区欧美精品| 亚洲一区二区三区在线| 亚洲欧美在线免费观看| 欧美在线91| 狂野欧美激情性xxxx欧美| 亚洲视频在线观看免费| 亚洲一区二区三区四区五区黄| 亚洲欧美日本国产有色| 久久精品伊人| 欧美国产欧美综合 | 久久夜色精品国产噜噜av| 亚洲国产精品成人| 日韩亚洲在线| 午夜宅男久久久| 久久综合久久综合久久| 亚洲国产欧美在线| 一区二区三区精品久久久| 亚洲欧美制服另类日韩| 久久久久久久久蜜桃| 欧美国产亚洲另类动漫| 国产精品久久久久久影院8一贰佰| 国产婷婷色一区二区三区| 亚洲国产mv| 亚洲专区一区二区三区| 卡一卡二国产精品| 日韩午夜在线视频| 久久不射中文字幕| 欧美另类高清视频在线| 麻豆精品国产91久久久久久| 欧美日韩国产经典色站一区二区三区| 国产精品第三页| 1000部国产精品成人观看| 亚洲天堂免费在线观看视频| 久久手机免费观看| 夜夜嗨av一区二区三区免费区| 欧美在线亚洲一区| 免费久久99精品国产| 久久一区国产| 亚洲视频在线免费观看| 久久综合99re88久久爱| 国产精品爱久久久久久久| 在线精品亚洲| 欧美在线亚洲| 欧美日韩国产a| 欧美日韩亚洲精品内裤| 久久se精品一区精品二区| 欧美国产综合一区二区| 国产日韩综合| 亚洲视频一区在线| 欧美激情日韩| 欧美主播一区二区三区| 欧美午夜精品电影| 亚洲高清免费视频| 久久九九精品99国产精品| 亚洲欧美日韩视频一区| 亚洲大片精品永久免费| 午夜精品久久久久久久白皮肤 | 亚洲一区二区三区高清不卡| 欧美大片免费观看在线观看网站推荐 | 亚洲午夜性刺激影院| 你懂的一区二区| 好吊色欧美一区二区三区视频| 亚洲一区二区三区高清不卡| 亚洲第一狼人社区| 久久九九免费| 国产一区二区看久久| 午夜视频在线观看一区| av成人福利| 欧美日韩国产精品专区| 亚洲人线精品午夜| 欧美韩国日本综合| 久久久午夜电影| 黄色成人精品网站| 久久久久久久成人| 欧美激情视频在线播放| 久久精品国产第一区二区三区最新章节| 国产精品久久九九| 亚洲影视在线播放| 在线观看视频日韩| 国产亚洲一区精品| 久久久久久久激情视频| 欧美一级在线播放|