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

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

常用鏈接

留言簿(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>
            一区二区高清在线| 午夜视频在线观看一区二区三区| 久久成人免费网| 国产性天天综合网| 久久九九国产精品怡红院| 欧美一区二区视频97| 在线成人h网| 亚洲七七久久综合桃花剧情介绍| 欧美1区3d| 亚洲视频观看| 久久av资源网站| 亚洲乱码国产乱码精品精98午夜| 亚洲欧洲日产国产网站| 国产精品国产精品国产专区不蜜| 香蕉av777xxx色综合一区| 欧美在线一区二区| 亚洲乱亚洲高清| 亚洲在线播放电影| 亚洲国产日韩欧美在线99 | 国产伦理一区| 久久综合伊人77777| 欧美精品手机在线| 欧美一区二区三区在线看| 久久裸体艺术| 亚洲午夜精品17c| 欧美在线网站| 亚洲午夜久久久久久尤物| 欧美一区二区三区在线观看| 亚洲美女在线看| 欧美在线视频一区二区三区| 一本色道久久99精品综合| 亚洲欧美激情视频| 亚洲美女黄网| 久久久久久高潮国产精品视| 在线综合亚洲| 欧美va亚洲va国产综合| 久久精品五月| 国产精品白丝黑袜喷水久久久 | 一道本一区二区| 久久国产日韩| 欧美一区二区三区视频在线观看| 裸体素人女欧美日韩| 欧美在线免费视频| 欧美视频精品在线| 亚洲国产成人久久综合| 国产日韩综合| 亚洲一区999| 一本色道久久| 欧美精品三级日韩久久| 你懂的视频欧美| 国产婷婷色综合av蜜臀av| 亚洲精品一区二区在线观看| 亚洲国产精品久久精品怡红院| 亚洲在线中文字幕| 亚洲自拍高清| 欧美日韩在线视频首页| 亚洲毛片在线看| 日韩五码在线| 欧美激情五月| 亚洲精品视频在线| 一区二区三区欧美在线观看| 欧美激情视频一区二区三区免费| 免费观看在线综合| 在线日韩av片| 久久这里只精品最新地址| 久久亚洲私人国产精品va| 国产视频综合在线| 欧美专区18| 另类欧美日韩国产在线| 影院欧美亚洲| 欧美jizz19hd性欧美| 欧美h视频在线| 亚洲欧洲精品一区二区精品久久久 | 亚洲小说春色综合另类电影| 欧美另类变人与禽xxxxx| 亚洲欧洲一区二区在线播放| 夜夜嗨av一区二区三区四季av| 欧美激情中文字幕乱码免费| 99国产精品国产精品毛片| 亚洲视频一区二区在线观看 | 午夜天堂精品久久久久| 欧美在线视频不卡| 国内久久视频| 美女精品一区| 一个色综合av| 久久久久久日产精品| 在线精品视频免费观看| 欧美精选在线| 亚洲综合电影一区二区三区| 久久精品噜噜噜成人av农村| 亚洲欧洲综合另类| 亚洲私人影吧| 国产手机视频一区二区| 久久久久看片| 日韩亚洲视频在线| 久久美女性网| 99国产精品久久久久老师| 国产精品日韩精品欧美精品| 久久国产乱子精品免费女| 亚洲国产成人tv| 亚洲欧美日韩在线综合| 亚洲高清色综合| 国产精品wwwwww| 久久综合中文字幕| 中文欧美日韩| 欧美高清视频www夜色资源网| 亚洲午夜视频在线观看| 玉米视频成人免费看| 欧美日韩一二三四五区| 久久久久久午夜| 亚洲午夜视频| 91久久精品美女高潮| 久久性色av| 亚洲综合视频一区| 亚洲精品美女免费| 韩日精品视频一区| 国产精品男gay被猛男狂揉视频| 久久影院午夜论| 性色一区二区| 亚洲少妇自拍| 亚洲精选91| 欧美刺激性大交免费视频| 欧美专区一区二区三区| 亚洲色在线视频| 日韩午夜一区| 亚洲国产小视频在线观看| 国模叶桐国产精品一区| 国产精品美女黄网| 欧美视频一区二区| 欧美激情麻豆| 欧美高潮视频| 欧美+亚洲+精品+三区| 久久亚洲国产精品一区二区| 欧美一区在线直播| 午夜亚洲性色福利视频| 亚洲欧美国产精品专区久久| 宅男噜噜噜66一区二区66| av成人福利| 99精品热视频| 99国产精品私拍| 日韩视频中文字幕| 一本大道久久a久久精二百| 亚洲激情av| 亚洲精品男同| 日韩一级裸体免费视频| 99精品欧美一区| 中国日韩欧美久久久久久久久| 夜夜爽av福利精品导航| 亚洲午夜免费视频| 亚洲欧美日韩国产中文| 久久成人精品电影| 久久在线免费视频| 免费美女久久99| 欧美精品一二三| 国产精品伦子伦免费视频| 国产精品实拍| 玉米视频成人免费看| 亚洲人成在线影院| 亚洲婷婷在线| 欧美在线在线| 欧美大片免费| 日韩视频在线观看免费| 亚洲欧美高清| 久久综合九色99| 欧美日韩精品中文字幕| 国产精品入口麻豆原神| 黄色av成人| 中文国产一区| 久久久久久一区二区三区| 欧美激情在线观看| 中国日韩欧美久久久久久久久| 午夜精彩国产免费不卡不顿大片| 久久久美女艺术照精彩视频福利播放 | 久久国产精品久久精品国产| 另类天堂av| 99精品视频一区二区三区| 欧美亚洲在线观看| 欧美国产欧美亚洲国产日韩mv天天看完整 | 久久久久国产一区二区三区四区| 欧美成人免费大片| 国产精品资源在线观看| 亚洲黄色av| 欧美在线观看网站| 亚洲国产精品免费| 午夜视频在线观看一区二区三区| 免费观看在线综合色| 国产乱子伦一区二区三区国色天香| 在线 亚洲欧美在线综合一区| 一本久道久久综合中文字幕| 久久久噜噜噜久久| 亚洲午夜成aⅴ人片| 老色批av在线精品| 国产欧美日韩激情| 一区二区三区欧美成人| 欧美成人免费小视频| 午夜在线播放视频欧美| 欧美日韩一区二区三区视频| 在线观看精品| 欧美自拍丝袜亚洲| 亚洲天堂av在线免费|