• <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>

            ACM PKU 1088 滑雪  經(jīng)典的動(dòng)態(tài)規(guī)劃備忘錄方法(記憶化搜索/Memory function )

            http://acm.pku.edu.cn/JudgeOnline/problem?id=1088

            非常經(jīng)典的一道動(dòng)態(tài)規(guī)劃題,AC的時(shí)候心情簡(jiǎn)直舒暢到了極點(diǎn).
            時(shí)間限制是1000MS,如果直接用DFS肯定超時(shí)的.
            馬上想到動(dòng)歸,
            用opt[i][j]記錄從點(diǎn)node[i][j]出發(fā)的最短路徑(不算本身,只算延伸;也就是初始值為0)
            狀態(tài)轉(zhuǎn)移方程opt[i][j]=max{ opt[i+1][j],opt[i-1][j],opt[i][j+1],opt[i][j-1] } +1    
            也就是說(shuō),opt[i][j]的值等于從node[i][j]的上下左右四個(gè)方向出發(fā)所滑的最長(zhǎng)值+1;
            而這道題并不是簡(jiǎn)單的動(dòng)歸,計(jì)算opt[i][j]的過(guò)程需要類似DFS的遞歸方法.這就是記憶化搜索. 


            Problem Id:1088  User Id:lnmm
            Memory:152K  Time:0MS
            Language:C++  Result:Accepted

             1#include"stdio.h"
             2const int dx[]={-1,0,1,0},dy[]={0,1,0,-1};
             3int r,c;//r和c分別是行和列
             4int node[101][101]; //放置每個(gè)坐標(biāo)上的高度
             5int opt[101][101]; //放置從每個(gè)坐標(biāo)出發(fā)的最優(yōu)解
             6
             7bool ok(int i,int j)
             8{
             9  return (i>=1 && i<=&& j>=1 &&j<=c);
            10}

            11
            12
            13
            14int dp(int i,int j)
            15{
            16    int k;
            17    if(opt[i][j]>0return opt[i][j];    //如果已經(jīng)計(jì)算出,直接返回
            18    for(k=0;k<4;k++)                    //向四個(gè)方向延伸
            19    {
            20        if(ok(i+dx[k],j+dy[k]))          //如果節(jié)點(diǎn)沒有超出邊界
            21            if( node[i+dx[k]][j+dy[k]]<node[i][j] )        //滿足滑雪條件
            22            {
            23                if(  opt[i][j]< dp(i+dx[k],j+dy[k])+1 ) 
            24                         opt[i][j]=dp(i+dx[k],j+dy[k])+1;
            25            }

            26    }

            27    return opt[i][j];
            28
            29
            30//       if(ok(i+dx[k],j+dy[k])&&node[i+dx[k]][j+dy[k]]<node[i][j]&&opt[i][j]>dp(i+dx[k],j+dy[k])+1)
            31//           opt[i][j]=dp(i+dx[k],j+dy[k])+1;
            32
            33     
            34
            35}

            36
            37void main()
            38{
            39    int max=0,i,j; 
            40    scanf("%d%d",&r,&c);
            41
            42    for(i=1;i<=r;i++)
            43        for(j=1;j<=c;j++)
            44            scanf("%d",&node[i][j]);
            45   for(i=1;i<=r;i++)
            46        for(j=1;j<=c;j++)
            47         opt[i][j]=0;
            48
            49    for(i=1;i<=r;i++)
            50        for(j=1;j<=c;j++)
            51            if(max<dp(i,j))max=dp(i,j);
            52    printf("%d",max+1);  //輸出值需要+1 ,因?yàn)樵谇懊娴挠?jì)算中,每個(gè)點(diǎn)的初始值都是0
            53
            54    return ;
            55}

            56

            posted on 2007-09-17 00:48 流牛ζ木馬 閱讀(5156) 評(píng)論(8)  編輯 收藏 引用

            評(píng)論

            # re: ACM PKU 1088 滑雪  經(jīng)典的動(dòng)態(tài)規(guī)劃備忘錄方法(記憶化搜索/Memory function ) 2008-03-19 11:08 wwyyy

            xie le   回復(fù)  更多評(píng)論   

            # re: ACM PKU 1088 滑雪  經(jīng)典的動(dòng)態(tài)規(guī)劃備忘錄方法(記憶化搜索/Memory function ) 2008-10-23 15:03 游客

            if(opt[i][j]>0) return opt[i][j]; //
            這句什么意思啊,如果
            數(shù)組是這樣的
            5 8 4
            7 9 6
            1 2 3
            由于有上邊那句是不答案就是3,其實(shí)是5  回復(fù)  更多評(píng)論   

            # re: ACM PKU 1088 滑雪  經(jīng)典的動(dòng)態(tài)規(guī)劃備忘錄方法(記憶化搜索/Memory function ) 2008-12-07 01:59 LonelyTree

            因?yàn)橐呀?jīng)求得了哦……
            看了blog,初步領(lǐng)會(huì)了備忘錄的強(qiáng)大,這個(gè)記憶化搜索跟DP結(jié)合起來(lái)……  回復(fù)  更多評(píng)論   

            # re: ACM PKU 1088 滑雪  經(jīng)典的動(dòng)態(tài)規(guī)劃備忘錄方法(記憶化搜索/Memory function ) 2008-12-22 11:18 hy

            建議初始o(jì)pt都設(shè)為1 比較好理解  回復(fù)  更多評(píng)論   

            # re: ACM PKU 1088 滑雪  經(jīng)典的動(dòng)態(tài)規(guī)劃備忘錄方法(記憶化搜索/Memory function ) 2009-03-03 21:07

            有一點(diǎn)不懂,拿NODE[2][1]=16 ,NODE[3][1]=15;但是在他順序求MAX時(shí)的時(shí)候,并沒有先求OPT[3][1]的值,他好象還是=0,那么OPT[2][1]不就是2了嗎???我比較面,不知道說(shuō)的對(duì)不???我說(shuō)錯(cuò)了,可別生氣呀~~我挺次的  回復(fù)  更多評(píng)論   

            # re: ACM PKU 1088 滑雪  經(jīng)典的動(dòng)態(tài)規(guī)劃備忘錄方法(記憶化搜索/Memory function ) 2009-06-04 20:58 大師傅啥的

            dfs不會(huì)超時(shí)的帥哥  回復(fù)  更多評(píng)論   

            # re: ACM PKU 1088 滑雪  經(jīng)典的動(dòng)態(tài)規(guī)劃備忘錄方法(記憶化搜索/Memory function ) 2011-05-29 10:46 Bourbon

            大N,你的Dp用的太飄逸了。
            為啥我看到dp的題都反應(yīng)不過(guò)來(lái)呢。
            有什么好方法沒?  回復(fù)  更多評(píng)論   

            # re: ACM PKU 1088 滑雪  經(jīng)典的動(dòng)態(tài)規(guī)劃備忘錄方法(記憶化搜索/Memory function ) 2013-04-18 10:58 eggjava

            我第一次見樓主的代碼的時(shí)候是2011年 現(xiàn)在再來(lái)看樓主的代碼2013年, 已然很明白了,樓主其實(shí)寫的就是一個(gè)深搜,但其實(shí)呢,它不僅僅是一個(gè)簡(jiǎn)單的盲目的深搜了,很顯然第一次的搜索就可以做一次記錄,當(dāng)然第一次沒有搜到的結(jié)點(diǎn)就不會(huì)有記錄,但是要搜r*c次,為后面的r*c次的搜索帶來(lái)很大的時(shí)間收益,這就是記憶化搜索。我也寫了一個(gè),還沒測(cè)試,后來(lái)和樓主的代碼一比較,呵呵,一樣哈,再次感謝樓主的博客給我?guī)?lái)的啟發(fā)
            public void dfs(int x,int y)
            {
            for(int i=0;i<4;i++)
            {
            int tx=x+stepx[i];
            int ty=y+stepy[i];
            if(isInMap(tx,ty)&&iscan(x,y,tx,ty))
            {
            if(mapping[x][y]+1>mapping[tx][ty])
            {
            mapping[tx][ty]=mapping[x][y]+1;
            dfs(tx,ty);
            }

            }
            }
            }  回復(fù)  更多評(píng)論   


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


            <2008年2月>
            272829303112
            3456789
            10111213141516
            17181920212223
            2425262728291
            2345678

            導(dǎo)航

            統(tǒng)計(jì)

            公告

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

            常用鏈接

            留言簿(6)

            隨筆檔案

            相冊(cè)

            搜索

            最新隨筆

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久亚洲精品中文字幕| 亚洲va久久久噜噜噜久久男同| 久久99久久99精品免视看动漫 | 久久精品成人欧美大片| 久久精品国产清自在天天线| 美女写真久久影院| 久久九九有精品国产23百花影院| 成人久久精品一区二区三区| 久久久一本精品99久久精品88| 久久久无码一区二区三区| 人妻无码中文久久久久专区| 成人久久精品一区二区三区| 精品多毛少妇人妻AV免费久久| 国产毛片久久久久久国产毛片| 四虎国产精品成人免费久久| 亚洲精品高清一二区久久| 久久er国产精品免费观看8| 久久精品国产99久久久香蕉| 久久午夜无码鲁丝片秋霞| 三级三级久久三级久久| 亚洲va久久久噜噜噜久久天堂| 99精品久久精品一区二区| 26uuu久久五月天| 无码人妻久久一区二区三区蜜桃 | 久久―日本道色综合久久| 久久香蕉综合色一综合色88| 精品免费久久久久国产一区| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 久久精品国产99国产电影网| 日本免费一区二区久久人人澡| 久久精品视频91| 久久综合亚洲欧美成人| 久久99久久成人免费播放| 熟妇人妻久久中文字幕| 精品久久久久国产免费| 97精品国产97久久久久久免费| 青青草原综合久久| 无码精品久久久天天影视| 九九久久精品无码专区| 久久久无码人妻精品无码| 伊人久久五月天|