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

ACM PKU 1695 Magazine Delivery 三維動態(tài)規(guī)劃

http://acm.pku.edu.cn/JudgeOnline/problem?id=1695
第一次做三位動態(tài)規(guī)劃,看了謝迪的《淺談動態(tài)規(guī)劃》,寫出如下程序

#include "stdio.h"

int f[33][33][33];
int d[33][33];
int maxint=99999;

void main()
{
    
int T,i,j,k,n,opt;
    scanf(
"%d",&T);
    
while(T--)
    
{
        scanf(
"%d",&n);
        
for(i=1;i<=n-1;i++//讀數(shù)據(jù)
            for(j=i+1;j<=n;j++)
            
{
                scanf(
"%d",&d[i][j]);
                d[j][i]
=d[i][j];
            
            }


        
for(i=1;i<=n;i++)//初始化
            for(j=1;j<=n;j++)
                
for(k=1;k<=n;k++)
                    f[i][j][k]
=maxint;
        
         f[
1][1][1]=0;

         
for(k=2;k<=n;k++)
             
for(i=1;i<k;i++)
                 
for(j=1;j<k;j++)
                     
if(f[i][j][k-1]!=maxint)
                     
{
                         
if(f[i][j][k-1]+d[i][k]<f[j][k-1][k])
                          f[j][k
-1][k]=f[i][j][k-1]+d[i][k];

                         
if(f[i][j][k-1]+d[j][k]<f[i][k-1][k])
                          f[i][k
-1][k]=f[i][j][k-1]+d[j][k];
                         
                         
if(f[i][j][k-1]+d[k-1][k]<f[i][k-1][k])
                         f[i][j][k]
=f[i][j][k-1]+d[k-1][k];
                     }


         opt
=f[1][1][n];
         
for(i=1;i<n;i++)
             
for(j=1;j<n;j++)
                 
if(f[i][j][n]<opt)opt=f[i][j][n];
         printf(
"%d\n",opt);



         
          



    }

}

本地調(diào)試成功,不過提交上去總是wa,郁悶了我一個多小時了.
唉..
不過總算是自己做了一次三維動態(tài)規(guī)劃了.希望哪個牛人可以告訴我這個程序哪里出問題了.

posted on 2007-11-08 01:35 流牛ζ木馬 閱讀(1069) 評論(5)  編輯 收藏 引用

評論

# re: ACM PKU 1695 Magazine Delivery 三維動態(tài)規(guī)劃 2007-11-10 21:19 Run&Run

能把狀態(tài)轉(zhuǎn)移方程寫一下嗎?  回復(fù)  更多評論   

# re: ACM PKU 1695 Magazine Delivery 三維動態(tài)規(guī)劃 2007-11-10 23:39 流牛ζ木馬

假設(shè)i,j<k
f[i][j][k-1]表示狀態(tài): 三個車分別在i,j,k-1的位置

狀態(tài)轉(zhuǎn)移有三個,要么是從某車i開到k ,要么是j開到k,要么是k-1開到k(遞推方式,每次加1)

所以狀態(tài)轉(zhuǎn)移方程是:
f[i][j][k-1]+d[i][k] -> f[j][k-1][k]
f[i][j][k-1]+d[j][k] -> f[i][k-1][k]
f[i][j][k-1]+d[k-1][k] -> f[i][k-1][k]

這是3維動態(tài)規(guī)劃的基本模型
唉,不知道怎么過不去啊~
你要是有興趣就幫忙測試一下吧~ 呵呵
  回復(fù)  更多評論   

# re: ACM PKU 1695 Magazine Delivery 三維動態(tài)規(guī)劃 2007-11-11 12:32 Run&Run

你第三個if語句錯了,
if(f[i][j][k-1]+d[k-1][k]<f[i][k-1][k])
f[i][j][k]=f[i][j][k-1]+d[k-1][k];
應(yīng)該是
if(f[i][j][k-1]+d[k-1][k]<f[i][j][k])
f[i][j][j]=f[i][j][k-1]+d[k-1][k];

還有就是你三個if語句都只寫了一半.只要細想一下就會發(fā)現(xiàn)
f[i][j][k]其實應(yīng)該是等于f[j][i][k]的,
所以每個if語句中都要再加上一條賦值語句.
我?guī)湍愀牧讼?AC了.修改如下.

f[1][1][1]=0;
for(k=2;k<=n;k++)
for(i=1;i<k;i++)
for(j=1;j<k;j++)
{
if(f[i][j][k-1]+d[i][k]<f[j][k-1][k])
{
f[j][k-1][k]=f[i][j][k-1]+d[i][k];
f[k-1][j][k]=f[i][j][k-1]+d[i][k];
}
if(f[i][j][k-1]+d[j][k]<f[i][k-1][k])
{
f[i][k-1][k]=f[i][j][k-1]+d[j][k];
f[k-1][i][k]=f[i][j][k-1]+d[j][k];
}
if(f[i][j][k-1]+d[k-1][k]<f[i][j][k])
{ f[i][j][k]=f[i][j][k-1]+d[k-1][k]; f[j][i][k]=f[i][j][k-1]+d[k-1][k];
}
}

  回復(fù)  更多評論   

# re: ACM PKU 1695 Magazine Delivery 三維動態(tài)規(guī)劃 2007-11-11 19:24 流牛ζ木馬

呵呵!感謝! 原來是這么細微的問題! 暈哦

謝謝哈

另外,你說的第二個問題是不存在的,我也考慮到你說的問題;因為你仍然用的
for(k=2;k<=n;k++)
for(i=1;i<k;i++)
for(j=1;j<k;j++)
仍然是完全窮舉
時間效率上沒有任何改進,反而因為重復(fù)計算降低了效率。
其實可以這樣改,會提高一點點效率:
for(k=2;k<=n;k++)
for(i=1;i<k;i++)
for(j=i;i<k;j++)

  回復(fù)  更多評論   

# re: ACM PKU 1695 Magazine Delivery 三維動態(tài)規(guī)劃 2008-04-26 14:06 DeathKnight

這個雖然ac 但是還不對
應(yīng)該需要先算一遍任意兩點間的最短距離

考慮下面這種情況:
從(1,2,3)-》(1,3,4)
那么從2開到4可以走的最短路并不一定是從2直接到4,你可以從2-》3-》4

給你一個例子:
1
4
2 5 6
2 2
8

你的算出來是9 但其實應(yīng)該是8

所以要么先算一遍最短路 要么把狀態(tài)考慮全 比如要算(1,2,2)這種狀態(tài)  回復(fù)  更多評論   


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2007年11月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

導(dǎo)航

統(tǒng)計

公告

MY Email/MSN :mars1021@163.com QQ : 27402040 流牛ζ木馬

常用鏈接

留言簿(6)

隨筆檔案

相冊

搜索

最新隨筆

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久9热精品视频| 久久综合网络一区二区| 最近看过的日韩成人| 美女在线一区二区| 亚洲激情第一页| 亚洲欧洲一级| 欧美午夜美女看片| 欧美一区二区三区在线| 欧美诱惑福利视频| 一区二区在线视频播放| 亚洲国产高清高潮精品美女| 欧美日韩激情网| 亚洲欧美日韩成人| 欧美制服第一页| 日韩亚洲欧美精品| 亚洲男人的天堂在线| 尤物99国产成人精品视频| 亚洲高清久久网| 国产精品手机视频| 欧美大片免费| 欧美午夜影院| 欧美成人首页| 国产精品美女久久久| 久久这里只有| 国产精品久久久久免费a∨大胸| 欧美在线观看你懂的| 免费不卡在线视频| 午夜精品福利视频| 免费在线观看成人av| 亚洲欧美一区二区在线观看| 久久久人成影片一区二区三区观看| 亚洲精品乱码久久久久久久久 | 亚洲精品一区二区在线| 一二三区精品| 亚洲电影成人| 亚洲欧美三级在线| 99爱精品视频| 久久国产福利| 午夜国产精品视频| 欧美国产精品专区| 久久天堂av综合合色| 欧美三级资源在线| 亚洲第一成人在线| 国产在线欧美日韩| 亚洲一区黄色| 亚洲午夜国产一区99re久久| 久久人人爽人人爽爽久久| 欧美一区二区三区喷汁尤物| 欧美激情一区二区| 欧美α欧美αv大片| 国产一区二区三区无遮挡| av成人天堂| 99热精品在线观看| 欧美福利一区二区| 欧美成人中文字幕在线| 国语自产偷拍精品视频偷 | 亚洲国产精品视频一区| 亚洲精品综合| 男女av一区三区二区色多| 国产精品看片资源| 99国产精品久久久久久久久久| 亚洲国产综合在线| 一区二区三区国产在线| 香蕉成人久久| 亚洲精品字幕| 国产亚洲一区在线播放| 欧美精品三级| 久久日韩精品| 亚洲制服丝袜在线| 亚洲国产精品va在看黑人| 羞羞答答国产精品www一本| 亚洲国产精品一区制服丝袜| 国产精品欧美精品| 欧美电影免费网站| 久久aⅴ国产紧身牛仔裤| 日韩视频在线观看免费| 噜噜噜91成人网| 午夜亚洲精品| 日韩一区二区电影网| 国际精品欧美精品| 国产精品劲爆视频| 能在线观看的日韩av| 欧美在线视频免费播放| 艳女tv在线观看国产一区| 欧美顶级艳妇交换群宴| 久久亚洲一区二区| 午夜伦理片一区| 亚洲视频久久| 日韩亚洲欧美一区二区三区| 亚洲国产精品久久久久婷婷884 | 亚洲综合色噜噜狠狠| 亚洲国产精品美女| 久久久国产精品一区| 小黄鸭精品密入口导航| 亚洲婷婷国产精品电影人久久| 亚洲国产欧美在线| 狠狠色狠狠色综合日日五| 国产欧美日韩高清| 国产精品国产成人国产三级| 欧美日韩二区三区| 男女视频一区二区| 美女精品在线观看| 久久综合九色综合欧美狠狠| 久久国产精品久久精品国产| 香蕉久久精品日日躁夜夜躁| 亚洲午夜精品福利| 一区二区三区视频观看| 一本大道久久a久久精二百| 亚洲精品久久久久久一区二区| 欧美3dxxxxhd| 欧美电影电视剧在线观看| 欧美肥婆在线| 91久久夜色精品国产网站| 亚洲国内自拍| 日韩视频在线一区二区三区| 亚洲精品午夜| 亚洲小视频在线| 午夜精品久久久99热福利| 午夜精品成人在线| 欧美在线视频观看| 久久久亚洲国产天美传媒修理工 | 亚洲网站视频| 午夜亚洲性色福利视频| 欧美专区日韩专区| 久久亚洲风情| 欧美国内亚洲| 国产精品美女久久久久av超清| 国产精品视频午夜| 国产一区导航| 亚洲精品一区中文| 亚洲视频在线二区| 欧美资源在线| 亚洲国产99精品国自产| 一区二区三区黄色| 亚洲一线二线三线久久久| 欧美中文字幕在线| 鲁大师影院一区二区三区| 欧美日韩精品在线观看| 国产日韩欧美三区| 亚洲国产黄色片| 亚洲欧美激情视频在线观看一区二区三区| 欧美专区中文字幕| 欧美韩日一区二区| 一区二区三区你懂的| 久久精品国产综合| 欧美日韩在线看| 亚洲电影天堂av| 亚洲在线黄色| 欧美jjzz| 亚洲欧美日韩国产综合精品二区| 久久久久99| 国产精品福利片| 亚洲国产精品国自产拍av秋霞| 亚洲综合另类| 欧美顶级大胆免费视频| 亚洲欧美日韩在线综合| 久久综合亚洲社区| 国产精品一区在线播放| 亚洲美女中文字幕| 久久久久.com| 一区二区三区 在线观看视| 久久午夜视频| 国产日韩在线播放| 这里是久久伊人| 欧美激情一区二区三区高清视频 | 性欧美videos另类喷潮| 亚洲国产欧美一区二区三区久久 | 精品不卡在线| 欧美一区1区三区3区公司| 亚洲第一视频网站| 久久精品一级爱片| 国产精品视频一| 亚洲午夜av| 亚洲欧洲久久| 蜜臀av一级做a爰片久久| 国产色综合天天综合网| 亚洲一区二区三区高清| 欧美福利一区二区| 久久婷婷蜜乳一本欲蜜臀| 国产一区二区三区久久久久久久久| 亚洲一区二区精品视频| 亚洲三级视频在线观看| 免费人成网站在线观看欧美高清| 国内精品福利| 久久av一区| 欧美一区二区三区免费观看 | 欧美视频亚洲视频| 日韩视频精品在线| 亚洲高清不卡一区| 欧美成人性生活| 亚洲电影有码| 免费视频一区二区三区在线观看| 欧美在线啊v| 国内精品国产成人| 久久久在线视频| 久久亚裔精品欧美| 91久久午夜| 亚洲免费电影在线| 欧美午夜精品久久久久久孕妇| 亚洲小说欧美另类婷婷|