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


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

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

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

            程序代碼:

             

              1 /*********************************************************************
              2 Author: littlekid
              3 Created Time: 2008-1-15 9:31:18
              4 Problem Source: 
              5 Description: 
              6     中間WA了兩次,查了很久,
              7     最后發(fā)現(xiàn)題目描述的是最多M層,每層最多N間房,原來弄反了!是個不小的教訓(xù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 閱讀(506) 評論(0)  編輯 收藏 引用 所屬分類: Problem Solving
            你是第 free hit counter 位訪客




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

            常用鏈接

            留言簿(4)

            隨筆分類(54)

            隨筆檔案(52)

            文章檔案(1)

            ACM/ICPC

            技術(shù)綜合

            最新隨筆

            搜索

            •  

            積分與排名

            • 積分 - 63313
            • 排名 - 356

            最新評論

            閱讀排行榜

            評論排行榜

            久久天天躁狠狠躁夜夜2020| 999久久久免费精品国产| 亚洲va中文字幕无码久久不卡| 久久免费的精品国产V∧| 久久久久99精品成人片三人毛片| 欧美国产成人久久精品| 国产精品99久久久久久宅男| 国产亚洲精久久久久久无码77777| 狠狠久久综合伊人不卡| 色综合久久久久无码专区 | 国产精品久久久久jk制服| 亚洲婷婷国产精品电影人久久| 久久精品国产久精国产| 91精品国产9l久久久久| 少妇高潮惨叫久久久久久| 亚洲欧美日韩中文久久| 思思久久99热只有频精品66| 99久久精品国产综合一区 | 精品久久久久久国产牛牛app| 99久久精品国产麻豆| 国产午夜精品久久久久免费视| 久久66热人妻偷产精品9| 色综合久久综合中文综合网| 久久亚洲精品国产亚洲老地址| 国产精品久久久久免费a∨| 国产精品久久久久久久久软件| 亚洲人成网站999久久久综合| 亚洲欧美精品一区久久中文字幕 | 久久精品国产色蜜蜜麻豆 | 久久国产色av免费看| 久久青青草原精品国产| 色综合久久天天综合| 久久99亚洲综合精品首页| 7777精品伊人久久久大香线蕉| 免费无码国产欧美久久18| 精品久久久久久中文字幕人妻最新| 99国产欧美久久久精品蜜芽| 久久精品国产一区| 久久亚洲sm情趣捆绑调教| 国内精品久久久久久野外| 久久嫩草影院免费看夜色|