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



May the force be with you!
posts - 52,  comments - 33,  trackbacks - 0

題目描述:
        有一棟樓有N(1<=N<=100)層,每層房間有M個房間(1<=M<=500)。每間房間有一個訪問開銷。從一個房間可以到其周邊(上一層同一號,同一層左右兩間)。現在要從一樓開始一直訪問到頂樓,問怎樣走可以獲得最小的訪問開銷?

解題思路:
      雙向DP。從一樓到頂樓依次計算從底樓到某一間房子的最小開銷。
      技巧點:對于某一層,先計算從下一層或左邊向右走的最小開銷,再嘗試從右邊走到左邊,看是不是開銷可以變小,是則更新。

程序代碼:

 

  1 /*********************************************************************
  2 Author: littlekid
  3 Created Time: 2008-1-15 9:31:18
  4 Problem Source: 
  5 Description: 
  6     中間WA了兩次,查了很久,
  7     最后發(fā)現題目描述的是最多M層,每層最多N間房,原來弄反了!是個不小的教訓
  8 ********************************************************************/
  9 
 10 # include <iostream>
 11 using namespace std;
 12 
 13 # define MAX 2000000005
 14 # define N 555
 15 # define M 111
 16 
 17 int n,m;
 18 long fee[ M ][ N ], f[ M ][ N ];;
 19 int road[ M ][ N ];
 20 
 21 void init()
 22 {
 23     scanf( "%d %d"&n, &m );
 24     for ( int i = 1; i <= n; i ++ )
 25     {
 26         for ( int j = 1; j <= m; j ++ )
 27         {
 28             scanf( "%d"&fee[ i ][ j ] );
 29         }
 30     }
 31 }
 32 
 33 void output()
 34 {
 35     int min = MAX, s = 1;
 36     for ( int i = 1; i <= m; i ++ )
 37     {
 38         if ( f[ n ][ i ] < min )
 39         {
 40             min = f[ n ][ i ];
 41             s = i;
 42         }
 43     }
 44     int step[ n*m+1 ];
 45     step[0= s; s=0;
 46     int floor = n;
 47     while ( floor > 1 )
 48     {
 49           s ++;
 50           step[ s ] = road[ floor ][ step[s-1] ];
 51           if ( step[ s ] == step[ s-1 ] )  floor --;
 52     }
 53     
 54     for ( int i = s; i >= 0; i -- )
 55     {
 56         printf( "%d\n", step[ i ] );
 57     }
 58 }
 59 
 60 void dp()
 61 {
 62     int tmp;
 63     for ( int i = 1; i <= m; i ++ )
 64     {
 65         road[1][ i ] = i;
 66         f[1][ i ] = fee[1][ i ];
 67     }
 68     for ( int floor = 2; floor <= n; floor ++ )
 69     {
 70         f[ floor ][1= f[ floor-1 ][ 1 ] + fee[ floor ][ 1 ];
 71         road[ floor ][1= 1;
 72         
 73         for ( int i = 2; i <= m; i ++ )
 74         {
 75             f[ floor ][ i ] = fee[ floor ][ i ];
 76             if ( f[ floor ][ i-1 ] < f[ floor-1 ][ i ] )
 77             {
 78                 f[ floor ][ i ] += f[ floor ][ i-1 ];
 79                 road[ floor ][ i ] = i-1;
 80             }
 81             else
 82             {
 83                 f[ floor ][ i ] += f[ floor-1 ][ i ];
 84                 road[ floor ][ i ] = i;
 85             }
 86         }
 87         
 88         for ( int i = m-1; i > 0; i -- )
 89         {
 90             tmp = f[ floor ][ i+1 ] + fee[ floor ][ i ];
 91             if ( tmp < f[ floor ][ i ] )
 92             {
 93                 f[ floor ][ i ] = tmp;
 94                 road[ floor ][ i ] = i+1;
 95             }
 96         }
 97     }
 98 }
 99 
100 int main()
101 {
102     int n,m;
103     init();
104     dp();
105     output();
106     return 0;
107 }
108 
109 


 

posted on 2008-01-15 11:10 R2 閱讀(517) 評論(0)  編輯 收藏 引用 所屬分類: Problem Solving
你是第 free hit counter 位訪客




<2008年1月>
303112345
6789101112
13141516171819
20212223242526
272829303112
3456789

常用鏈接

留言簿(4)

隨筆分類(54)

隨筆檔案(52)

文章檔案(1)

ACM/ICPC

技術綜合

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 64560
  • 排名 - 357

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久疯狂做爰流白浆xx| 国产精品免费区二区三区观看| 欧美成人精品影院| 国产午夜精品一区二区三区视频 | 一区二区冒白浆视频| 91久久精品国产91久久性色tv | 国产一区二区视频在线观看| 国产精品女主播在线观看 | 尤物精品在线| 在线观看一区视频| 亚洲精品国久久99热| 999亚洲国产精| 亚洲最新在线| 久久福利电影| 欧美国产欧美综合| 99re视频这里只有精品| 亚洲在线观看免费| 久久一区亚洲| 欧美精品日韩| 国产精品欧美日韩一区| 红桃av永久久久| 日韩写真在线| 欧美在线关看| 欧美丰满高潮xxxx喷水动漫| 亚洲精品一区二区三区av| 99国产精品99久久久久久粉嫩 | 99日韩精品| 午夜一区二区三视频在线观看| 久久er99精品| 欧美精品自拍偷拍动漫精品| 国产精品中文在线| 亚洲精选在线观看| 久久久久久久久久久久久女国产乱| 欧美激情一区二区三区成人| 亚洲少妇最新在线视频| 久久婷婷久久一区二区三区| 免费看黄裸体一级大秀欧美| 国产精品视频免费观看| 亚洲一区二区三区在线播放| 国内久久精品| 亚洲人成网站999久久久综合| 亚洲一区二区三区在线观看视频| 麻豆91精品| 亚洲图色在线| 欧美高清hd18日本| 在线免费观看日本欧美| 欧美一区二区在线| 亚洲精品久久久久久久久久久| 亚洲欧美中文日韩在线| 欧美日韩精品三区| 亚洲成人原创| 久久五月天婷婷| 午夜精品三级视频福利| 欧美视频专区一二在线观看| 亚洲国产精品一区制服丝袜| 久久国产免费| 亚洲一线二线三线久久久| 欧美激情视频在线播放| 亚洲国产第一页| 牛牛影视久久网| 欧美综合77777色婷婷| 国产一区日韩二区欧美三区| 午夜精品一区二区三区在线播放 | 亚洲视频一起| 欧美精品1区2区| 亚洲青涩在线| 亚洲大片免费看| 免费日本视频一区| 亚洲人成在线观看一区二区| 美女精品视频一区| 久久在线免费观看视频| 亚洲国产黄色片| 欧美ed2k| 欧美精品一区二区高清在线观看| 久久岛国电影| 久久久久天天天天| 亚洲国产日韩在线一区模特| 欧美激情视频免费观看| 欧美成年人视频| 亚洲免费观看| 一本综合久久| 国产日韩精品一区二区| 快she精品国产999| 欧美黄色视屏| 午夜精品在线看| 欧美一区二区三区喷汁尤物| 在线观看日韩av先锋影音电影院| 欧美高清视频在线观看| 欧美日韩精品综合在线| 午夜在线观看欧美| 久久久久国产精品一区三寸| 亚洲精品久久久一区二区三区| 99re8这里有精品热视频免费 | 国产性猛交xxxx免费看久久| 午夜精品久久久久久久白皮肤| 国产精品高精视频免费| 欧美一区二区三区久久精品| 久久精品成人| 99亚洲视频| 午夜久久久久| 亚洲激情啪啪| 亚洲一区二区三区久久| 精品91视频| 亚洲欧美激情四射在线日| 亚洲欧美日本视频在线观看| 国产欧美韩日| 免费观看日韩| 欧美人与禽猛交乱配视频| 欧美一区二视频| 欧美成人精品h版在线观看| 亚洲午夜精品| 久久精品最新地址| 亚洲午夜视频在线观看| 久久av免费一区| 亚洲午夜精品一区二区三区他趣| 欧美中文字幕视频在线观看| 99天天综合性| 免费亚洲婷婷| 久久久精品视频成人| 欧美日韩午夜| 欧美刺激性大交免费视频| 国产精品日韩在线| 亚洲激情婷婷| 精品av久久久久电影| 亚洲一区二区三区免费视频| 亚洲美女黄网| 久久久久久69| 久久成人免费| 国产精品黄页免费高清在线观看| 媚黑女一区二区| 国产亚洲精品aa午夜观看| 亚洲精品一二三| 亚洲精品免费在线播放| 久久夜色撩人精品| 欧美v日韩v国产v| 国产性天天综合网| 亚洲尤物在线| 欧美一区二区三区的| 国产精品日本| 99精品国产热久久91蜜凸| 亚洲人成在线观看| 美国十次成人| 欧美激情中文字幕乱码免费| 亚洲电影一级黄| 久久天堂av综合合色| 久久视频免费观看| 国内揄拍国内精品少妇国语| 久久国产免费看| 久久青草福利网站| 国产专区综合网| 欧美在线视频一区二区| 久久久久亚洲综合| 在线成人欧美| 女生裸体视频一区二区三区| 欧美成人官网二区| 亚洲黄色av| 欧美久久电影| 欧美成人69av| 亚洲欧美制服另类日韩| 欧美午夜一区| 午夜精品www| 久久久综合视频| 亚洲国产人成综合网站| 免费日韩av片| 亚洲一区二区精品在线| 久久国产精品网站| 亚洲激情第一区| 欧美精品一区二区三区四区 | 亚洲人线精品午夜| 亚洲视频精品| 国产午夜精品一区二区三区欧美| 久久人人爽爽爽人久久久| 欧美激情网站在线观看| 99在线精品观看| 国产欧美精品日韩区二区麻豆天美| 性欧美videos另类喷潮| 欧美jizz19hd性欧美| 亚洲视频欧美视频| 国产一区二区三区高清在线观看| 久久综合色一综合色88| 在线亚洲免费视频| 久久一本综合频道| 一区二区三区精品| 激情六月婷婷综合| 欧美日韩精选| 可以看av的网站久久看| 亚洲一区在线播放| 亚洲国产精品99久久久久久久久| 亚洲天堂视频在线观看| 一区二区三区在线免费播放| 欧美日韩一区在线| 蜜臀av一级做a爰片久久| 亚洲性图久久| 亚洲美女黄网| 欧美国产精品久久| 久久久精品一品道一区| 午夜精品www| 亚洲综合日本| 一区二区三区四区精品| 亚洲欧洲午夜|