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

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)沒(méi)有超出邊界
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 流牛ζ木馬 閱讀(5168) 評(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í)候,并沒(méi)有先求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)呢。
有什么好方法沒(méi)?  回復(fù)  更多評(píng)論   

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

我第一次見(jiàn)樓主的代碼的時(shí)候是2011年 現(xiàn)在再來(lái)看樓主的代碼2013年, 已然很明白了,樓主其實(shí)寫(xiě)的就是一個(gè)深搜,但其實(shí)呢,它不僅僅是一個(gè)簡(jiǎn)單的盲目的深搜了,很顯然第一次的搜索就可以做一次記錄,當(dāng)然第一次沒(méi)有搜到的結(jié)點(diǎn)就不會(huì)有記錄,但是要搜r*c次,為后面的r*c次的搜索帶來(lái)很大的時(shí)間收益,這就是記憶化搜索。我也寫(xiě)了一個(gè),還沒(méi)測(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年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

導(dǎo)航

統(tǒng)計(jì)

公告

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

常用鏈接

留言簿(6)

隨筆檔案

相冊(cè)

搜索

最新隨筆

最新評(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>
            国产精品尤物| 欧美高清视频在线| 一区二区三区日韩| 欧美国产日本在线| 久久久久久久久久久久久久一区| 99热这里只有成人精品国产| 国产一区二区三区四区五区美女| 欧美日韩在线精品| 欧美不卡在线| 久久久91精品国产| 亚洲欧美视频在线观看视频| 99这里有精品| 亚洲国产美女久久久久| 老司机成人在线视频| 欧美一级网站| 亚洲欧美在线免费观看| 一本大道久久精品懂色aⅴ| 91久久久久久| 一区二区三区在线看| 国产一区观看| 国产一区二区三区免费在线观看| 国产精品免费小视频| 国产精品久久久久久久久搜平片| 欧美日韩国产123| 欧美成人日本| 欧美大片专区| 欧美国产视频在线观看| 欧美~级网站不卡| 免费在线看一区| 美女脱光内衣内裤视频久久网站| 久久午夜精品| 免费精品视频| 欧美激情一区二区三区成人| 欧美肥婆在线| 欧美日韩的一区二区| 欧美日韩精品免费观看视一区二区| 欧美国产精品va在线观看| 欧美大片一区二区| 欧美人妖在线观看| 欧美色另类天堂2015| 国产精品jvid在线观看蜜臀| 国产精品激情| 国产亚洲精品久久久| 国语自产偷拍精品视频偷| 在线观看国产日韩| 亚洲国产一区二区精品专区| 亚洲乱码久久| 亚洲私人影院在线观看| 销魂美女一区二区三区视频在线| 欧美在线二区| 免费在线日韩av| 亚洲动漫精品| 亚洲少妇中出一区| 欧美在线观看一区二区| 久久影院午夜片一区| 欧美激情综合网| 国产精品美女久久久免费| 国内偷自视频区视频综合| 亚洲国产高清高潮精品美女| 日韩亚洲在线观看| 欧美一区二区三区在| 欧美阿v一级看视频| 亚洲免费观看高清在线观看| 亚洲影院在线| 免费看黄裸体一级大秀欧美| 欧美日韩亚洲综合| 国内一区二区三区| 日韩亚洲欧美在线观看| 欧美综合国产精品久久丁香| 欧美不卡视频一区发布| 亚洲视频999| 久久一区二区三区四区五区| 欧美日韩一级黄| 国产一区二区无遮挡| 99re这里只有精品6| 久久精品72免费观看| 亚洲国产精品99久久久久久久久| 亚洲天堂av在线免费| 久久女同精品一区二区| 欧美视频在线观看一区| 亚洲成人在线网站| 午夜一区二区三区不卡视频| 亚洲第一视频网站| 欧美一区二区成人| 欧美午夜电影在线| 一色屋精品亚洲香蕉网站| 亚洲一区二区三区激情| 欧美成人中文字幕| 性欧美超级视频| 欧美视频在线观看免费网址| 亚洲国产黄色| 久久se精品一区精品二区| 日韩视频在线观看免费| 久久婷婷激情| 国产亚洲欧美日韩日本| 亚洲一区二区在线观看视频| 欧美激情中文字幕在线| 欧美一区二区视频观看视频| 欧美日韩影院| 亚洲精选一区| 免费av成人在线| 性欧美长视频| 国产精品无码专区在线观看| 日韩网站在线看片你懂的| 欧美不卡视频一区发布| 欧美在线短视频| 国产乱码精品1区2区3区| 国产精品99久久久久久www| 欧美激情五月| 美日韩在线观看| 精品1区2区3区4区| 久久久亚洲一区| 亚久久调教视频| 国产欧美日韩麻豆91| 午夜精品成人在线视频| av不卡在线看| 欧美日韩伦理在线| 一区二区久久久久| 亚洲三级影院| 欧美日本免费一区二区三区| 亚洲精品久久久蜜桃| 欧美激情免费在线| 免费成人高清视频| 亚洲精品欧美极品| 亚洲黄网站在线观看| 欧美电影美腿模特1979在线看 | 性欧美暴力猛交另类hd| 一二三区精品| 国产精品黄色在线观看| 亚洲欧美日韩一区二区三区在线观看 | 亚洲综合清纯丝袜自拍| 一区二区三区高清在线观看| 欧美日韩午夜在线视频| 亚洲无亚洲人成网站77777| 99精品欧美| 国产精品久久久久一区| 欧美一区二区三区在线视频 | 娇妻被交换粗又大又硬视频欧美| 久久久久亚洲综合| 久久久欧美一区二区| 亚洲欧洲日本在线| 亚洲精选成人| 国产精品久久久久久久久免费桃花| 亚洲免费影视第一页| 欧美亚洲一区| 在线观看欧美日本| 亚洲黄色三级| 国产精品久久久久毛片软件| 亚洲欧美日韩一区二区在线| 羞羞视频在线观看欧美| 影音先锋在线一区| 亚洲日本电影| 国产精品一区二区久久久久| 久久综合九色欧美综合狠狠| 欧美freesex交免费视频| 一区二区三区国产在线| 亚洲欧美成人在线| 尤物网精品视频| 亚洲精品五月天| 国产麻豆91精品| 欧美福利视频网站| 国产精品a级| 美日韩精品视频| 欧美日韩国产综合网| 久久精品视频播放| 欧美成人a∨高清免费观看| 亚洲午夜久久久久久尤物 | 亚洲一区二区三区视频播放| 黑人一区二区| 日韩视频在线观看| 国产一区二区三区久久悠悠色av| 亚洲国产精品专区久久| 国产精品羞羞答答xxdd| 欧美成人免费小视频| 国产精品久久久久久久9999| 免费人成精品欧美精品| 欧美亚洲不卡| 欧美激情视频在线免费观看 欧美视频免费一 | 亚洲免费高清视频| 在线观看av不卡| 亚洲先锋成人| 亚洲日本欧美| 久久国产精品网站| 亚洲一区三区电影在线观看| 老巨人导航500精品| 亚洲欧美视频一区| 欧美国产精品人人做人人爱| 欧美中文在线观看| 欧美日韩国产综合网| 欧美aa在线视频| 国产日韩精品入口| 亚洲美女啪啪| 亚洲国产免费| 久久精品色图| 欧美一区二区成人6969| 欧美日韩国产精品专区| 免费在线观看一区二区| 国产日韩精品久久| 亚洲一区二区黄色| 一二三区精品|