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

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年11月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋

題目地址:
         http://acm.hdu.edu.cn/showproblem.php?pid=1548
題目描述:
A strange lift
Time Limit: 
2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 
2641    Accepted Submission(s): 944


Problem Description
There 
is a strange lift.The lift can stop can at every floor as you want, and there is a number Ki(0 <= Ki <= N) on every floor.The lift have just two buttons: up and down.When you at floor i,if you press the button "UP" , you will go up Ki floor,i.e,you will go to the i+Ki th floor,as the same, if you press the button "DOWN" , you will go down Ki floor,i.e,you will go to the i-Ki th floor. Of course, the lift can't go up high than N,and can't go down lower than 1. For example, there is a buliding with 5 floors, and k1 = 3, k2 = 3,k3 = 1,k4 = 2, k5 = 5.Begining from the 1 st floor,you can press the button "UP", and you'll go up to the 4 th floor,and if you press the button "DOWN", the lift can'do it, because it can't go down to the -2 th floor,as you know ,the -2 th floor isn't exist.
Here comes the problem: when you 
is on floor A,and you want to go to floor B,how many times at least he havt to press the button "UP" or "DOWN"?

 

Input
The input consists of several test cases.,Each test 
case contains two lines.
The first line contains three integers N ,A,B( 
1 <= N,A,B <= 200) which describe above,The second line consist N integers k1,k2,.kn.
A single 
0 indicate the end of the input.
 

Output
For each 
case of the input output a interger, the least times you have to press the button when you on floor A,and you want to go to floor B.If you can't reach floor B,printf "-1".
 

Sample Input
5 1 5
3 3 1 2 5
0
 

Sample Output
3

題目分析:
        這題又是一個標準的  Dijkstra 算法的題目 ( 最短路 ).  要說難度嗎?  對我而言吧, 就是 圖的生成.
剛開始做的時候自己想復雜了, 以為從不同的樓層開始, 就有不同的走法, 所以開始的時候寫循環沒寫對,
就寫成了遞歸.   結果很杯具的 STACK_OVERFLOW........   在 AMB 神牛的指點發現, 原來是自己想復雜了,
只需要計算出每一個樓層的 上樓 和 下樓就可以了, 當然, 要注意是否越界.  圖生成后, 當然就是 DIJKSTRA了.

閑來無事, 又復制一遍 :
            Dijkstra算法的基本思路是:

         假設每個點都有一對標號 (dj, pj),其中dj是從起源點s到點j的最短路徑的長度 (從頂點到其本身的最短路徑是零路(沒有弧的路),其長度等于零);

pj則是從s到j的最短路徑中j點的前一點。求解從起源點s到點j的最短路徑算法的基本過程如下:

  1) 初始化。起源點設置為:① ds=0, ps為空;② 所有其他點: di=∞, pi=?;③ 標記起源點s,記k=s,其他所有點設為未標記的。

  2) 檢驗從所有已標記的點k到其直接連接的未標記的點j的距離,并設置:


dj=min[dj, dk+lkj]


式中,lkj是從點k到j的直接連接距離。

  3) 選取下一個點。從所有未標記的結點中,選取dj 中最小的一個i:


di=min[dj, 所有未標記的點j]


點i就被選為最短路徑中的一點,并設為已標記的。

  4) 找到點i的前一點。從已標記的點中找到直接連接到點i的點j*,作為前一點,設置:i=j*

  5) 標記點i。如果所有點已標記,則算法完全推出,否則,記k=i,轉到2) 再繼續。



代碼如下:
#include <iostream>
using namespace std;
const int MAX = 200;
const int INF = 0x7FFFFFF;
int N,A,B;
int g[MAX+1][MAX+1];
int hash[MAX+1];
int path[MAX+1];
int K[MAX+1];
int Dijkstra ( int beg , int end )
{
    path[beg] 
= 0;
    hash[beg] 
= false;
    
while ( beg != end )
    {
            
int m = INF, temp;
            
for ( int i = 1; i <= N; ++ i )
            {
                  
if ( g[beg][i] != INF )
                       path[i] 
= min ( path[i], path[beg] + g[beg][i] );
                  
if ( m > path[i] && hash[i] )
                  {
                       m 
= path[i];
                       temp 
= i; 
                  }           
            }
            beg 
= temp;
            
if ( m == INF )
                 
break;
            hash[beg] 
= false;
    }
    
if ( path[end] == INF )
         
return -1;
    
return path[end]; 
}

int main ()
{
    
while ( scanf ( "%d%d%d"&N, &A, &B ) , N )
    {
            
for ( int i = 0; i <= MAX; ++ i )
            {
                  hash[i] 
= true;
                  path[i] 
= INF;
                  
for ( int j = 0; j <= MAX; ++ j )
                  {
                        g[i][j] 
= INF;
                  } 
            }
            
for ( int i = 1; i <= N; ++ i )
            {
                  scanf ( 
"%d",&K[i] );
            } 
            
for ( int i = 1; i <= N; ++ i )
            {
                  
if ( i + K[i] <= N )
                       g[ i ][ i 
+ K[i] ] = 1
                  
if ( i - K[i] >= 1 )
                       g[ i ][ i 
- K[i] ] = 1
            }
            cout 
<< Dijkstra ( A, B ) << endl;
    }
    
return 0
}


SO 代碼:
#include <iostream>
using namespace std;
const int MAX = 200;
const int INF = 0x7FFFFFF;
bool UP = true;
bool DOWN = false;
int N,A,B;
int g[MAX+1][MAX+1];
int hash[MAX+1];
int path[MAX+1];
int K[MAX+1];

int Dijkstra ( int beg , int end )
{
    path[beg] 
= 0;
    hash[beg] 
= false;
    
while ( beg != end )
    {
            
int m = INF, temp;
            
for ( int i = 1; i <= N; ++ i )
            {
                  
if ( g[beg][i] != INF )
                       path[i] 
= min ( path[i], path[beg] + g[beg][i] );
                  
if ( m > path[i] && hash[i] )
                  {
                       m 
= path[i];
                       temp 
= i; 
                  }           
            }
            beg 
= temp;
            
if ( m == INF )
                 
break;
            hash[beg] 
= false;
    }
    
if ( path[end] == INF )
         
return -1;
    
return path[end]; 
}

bool setGraph ( int n, bool flag )
{
     
if ( flag ) 
     {
          
if ( n + K[n] <= N )
          {
               g[ n ][ n 
+ K[n] ] = 1;
               setGraph ( n 
+ K[n], UP );
               setGraph ( n 
+ K[n], DOWN );
          }  
     }
     
else
     {
          
if ( n - K[n] >= 1 )
          {
               g[ n  ][ n 
- K[n] ] = 1;
               setGraph ( n 
- K[n], UP );
               setGraph ( n 
- K[n], DOWN ); 
          } 
     }
     
return true;
}
int main ()
{
    
while ( scanf ( "%d%d%d"&N, &A, &B ) , N )
    {
            
for ( int i = 0; i <= MAX; ++ i )
            {
                  hash[i] 
= true;
                  path[i] 
= INF;
                  
for ( int j = 0; j <= MAX; ++ j )
                  {
                        g[i][j] 
= INF;
                  } 
            }
            
for ( int i = 1; i <= N; ++ i )
            {
                  scanf ( 
"%d",&K[i] );
            } 
            
for ( int i = 1; i <= N; ++ i )
            {
                  setGraph ( i, UP );
                  setGraph ( i, DOWN ); 
            }
            cout 
<< Dijkstra ( A, B ) << endl;
    }
    
return 0
}
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久国产欧美日韩精品| 美女国产精品| 国产精品大全| 在线观看视频一区二区欧美日韩| 国产精品igao视频网网址不卡日韩| 久久久亚洲高清| 国产热re99久久6国产精品| 一区二区三区.www| av成人手机在线| 最新亚洲激情| 91久久综合| 久久久久久久999精品视频| 免费亚洲电影| 久久国产一区二区三区| 亚洲第一天堂无码专区| 欧美激情成人在线| 欧美午夜精品久久久| 国产在线不卡视频| 国产精品亚洲а∨天堂免在线| 久久久久久网站| 欧美在线播放视频| 国产日韩欧美不卡在线| 国产精品男gay被猛男狂揉视频| 免费亚洲视频| 久久精品女人的天堂av| 正在播放欧美视频| 性做久久久久久久免费看| 亚洲在线一区二区三区| 亚洲国产精品成人精品| 欧美国产另类| 午夜精品福利在线| 欧美日产一区二区三区在线观看| 国产亚洲毛片| 国产农村妇女精品一二区| 1024欧美极品| 久久精品亚洲一区二区| 夜夜嗨av一区二区三区网站四季av| 欧美一区在线直播| 欧美中文字幕视频| 久久av在线| 欧美影院成年免费版| 欧美巨乳在线| 亚洲日本黄色| 夜夜嗨网站十八久久| 亚洲久久一区| 免费不卡中文字幕视频| 欧美一级理论片| 国产精品视频一| 国产欧美欧美| 亚洲精品美女91| 国产一区二区三区四区| 久久九九久久九九| 欧美日本不卡视频| 在线一区二区三区四区| 欧美激情综合| 国产伦理精品不卡| 久久午夜色播影院免费高清| 亚洲午夜国产成人av电影男同| 久久成人精品视频| 国产精品久久久久久模特| 国产精品wwwwww| 国产精品久久久久久久久久免费看| 亚洲国产精品成人一区二区| 亚洲人午夜精品免费| 免费91麻豆精品国产自产在线观看| 欧美激情视频在线免费观看 欧美视频免费一 | 亚洲高清不卡在线| 欧美大片91| 久久理论片午夜琪琪电影网| 欧美成人高清| 亚洲人体一区| 欧美一级专区| 亚洲欧美日韩精品一区二区| 老**午夜毛片一区二区三区| 在线看成人片| 亚洲黄网站在线观看| 欧美日韩免费观看一区=区三区| 一本久道久久综合婷婷鲸鱼| 中文精品99久久国产香蕉| 久久九九久精品国产免费直播| 国产午夜精品一区理论片飘花| 亚洲第一福利在线观看| 欧美gay视频| 欧美日韩mv| 亚洲免费视频在线观看| 欧美制服第一页| 国产精品多人| 最新69国产成人精品视频免费| 亚洲一区中文字幕在线观看| 久久成人18免费网站| 一本一本大道香蕉久在线精品| 欧美成人国产va精品日本一级| 久热精品视频在线免费观看| 亚洲精品乱码| 理论片一区二区在线| 国产精品区一区二区三| 久久精品国产一区二区三| 日韩一级在线观看| 免费h精品视频在线播放| 欧美日韩国产a| 欧美在线观看网址综合| 欧美v国产在线一区二区三区| 国产精品外国| 久久一二三四| 欧美制服丝袜| 亚洲另类在线视频| 亚洲成人自拍视频| 欧美精品一区二区在线观看| 国内精品嫩模av私拍在线观看| 久久影音先锋| 亚洲欧美日韩综合国产aⅴ| 极品尤物久久久av免费看| 亚洲理伦在线| 久久天堂精品| 国内自拍一区| 亚洲婷婷国产精品电影人久久| 亚洲黄色小视频| 久久久久久久久综合| 久久精品国产77777蜜臀| 欧美日韩视频一区二区三区| 一区二区精品国产| 亚洲精品社区| 国自产拍偷拍福利精品免费一| 国产精品99久久久久久久久久久久| 国产精品黄视频| 亚洲激情校园春色| 欧美高清在线| 亚洲国产专区| 久久久久se| 亚洲精品在线视频| 亚洲九九九在线观看| 亚洲国产午夜| 欧美成年网站| 午夜精品免费| 国产精品扒开腿做爽爽爽软件| 99精品国产热久久91蜜凸| 中国女人久久久| 欧美系列电影免费观看| 一本色道久久综合狠狠躁的推荐| 99热精品在线观看| 亚洲欧美日韩久久精品| 香蕉久久精品日日躁夜夜躁| 国产精品美腿一区在线看| 久久人人精品| 欧美日韩福利在线观看| 99ri日韩精品视频| 午夜精品福利电影| 久久婷婷综合激情| 在线亚洲精品| 国产精品国产三级国产专播品爱网| 一本色道久久综合亚洲精品高清| 亚洲性夜色噜噜噜7777| 夜夜嗨av一区二区三区| 在线不卡欧美| 国产精品卡一卡二卡三| 欧美凹凸一区二区三区视频| 亚洲天堂av综合网| 99国产精品久久久| 亚洲理论在线观看| 免费日韩成人| 久久一区二区三区超碰国产精品| 国产日韩欧美高清免费| 欧美精品一区二区三区很污很色的| 欧美精品一区二区三区很污很色的 | 在线不卡视频| 一区二区激情小说| 亚洲欧美日韩另类| 精品不卡在线| 欧美日韩一区二区三区在线 | 久久精品在线观看| 亚洲欧美日韩在线不卡| 国产在线观看精品一区二区三区| 一区二区激情视频| 久久九九热免费视频| 亚洲日本理论电影| 狼狼综合久久久久综合网| 99av国产精品欲麻豆| 久久亚洲国产成人| 在线视频精品一区| 在线观看亚洲精品视频| 欧美午夜精品理论片a级按摩| 亚洲国产欧美一区二区三区同亚洲 | 亚洲综合精品四区| 亚洲美女精品成人在线视频| 欧美视频久久| 久久精品免费播放| 久久综合狠狠综合久久综合88| 亚洲女性裸体视频| 亚洲少妇中出一区| 亚洲欧洲在线免费| 国产热re99久久6国产精品| 国产精品久久综合| 嫩模写真一区二区三区三州| 亚洲免费福利视频| 国产日韩欧美亚洲一区| 亚洲一区二区黄色| 9色porny自拍视频一区二区| 欧美大片一区| 亚洲精品视频在线看| 欧美精品亚洲精品|