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

PKU 2251 用DFS TLE了 BFS AC了

                                                                       Dungeon Master
Time Limit: 1000MS Memory Limit: 65536K
Total Submissions: 6561 Accepted: 2610

Description

You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is composed of unit cubes which may or may not be filled with rock. It takes one minute to move one unit north, south, east, west, up or down. You cannot move diagonally and the maze is surrounded by solid rock on all sides.

Is an escape possible? If yes, how long will it take?

Input

The input consists of a number of dungeons. Each dungeon description starts with a line containing three integers L, R and C (all limited to 30 in size).
L is the number of levels making up the dungeon.
R and C are the number of rows and columns making up the plan of each level.
Then there will follow L blocks of R lines each containing C characters. Each character describes one cell of the dungeon. A cell full of rock is indicated by a '#' and empty cells are represented by a '.'. Your starting position is indicated by 'S' and the exit by the letter 'E'. There's a single blank line after each level. Input is terminated by three zeroes for L, R and C.

Output

Each maze generates one line of output. If it is possible to reach the exit, print a line of the form
Escaped in x minute(s).

where x is replaced by the shortest time it takes to escape.
If it is not possible to escape, print the line
Trapped!

Sample Input

3 4 5
S....
.###.
.##..
###.#
#####
#####
##.##
##...
#####
#####
#.###
####E
1 3 3
S##
#E#
###
0 0 0

Sample Output

Escaped in 11 minute(s).
Trapped!

三維迷宮問題
據說要用BFS,范圍30 ,我以為DFS能搞定的,為什么會超時呢????
 1#include<iostream>
 2#include<string.h>
 3using namespace std;
 4char G[35][35][35];
 5bool g[35][35][35];
 6void dfs(int l,int r,int c)
 7{
 8     if(G[l][r][c]==0||G[l][r][c]=='#')return ;
 9     if((G[l+1][r][c]=='.'||G[l+1][r][c]>G[l][r][c])&&G[l+1][r][c]!=0&&G[l+1][r][c]!='#') { G[l+1][r][c]=G[l][r][c]+1;g[l+1][r][c]=1;dfs(l+1,r,c);}
10     if((G[l][r-1][c]=='.'||G[l][r-1][c]>G[l][r][c])&&G[l][r-1][c]!=0&&G[l][r-1][c]!='#') { G[l][r-1][c]=G[l][r][c]+1;g[l][r-1][c]=1;dfs(l,r-1,c);}  
11     if((G[l][r+1][c]=='.'||G[l][r+1][c]>G[l][r][c])&&G[l][r+1][c]!=0&&G[l][r+1][c]!='#') { G[l][r+1][c]=G[l][r][c]+1;g[l][r+1][c]=1;dfs(l,r+1,c);}
12     if((G[l][r][c-1]=='.'||G[l][r][c-1]>G[l][r][c])&&G[l][r][c-1]!=0&&G[l][r][c-1]!='#') { G[l][r][c-1]=G[l][r][c]+1;g[l][r][c-1]=1;dfs(l,r,c-1);}
13     if((G[l][r][c+1]=='.'||G[l][r][c+1]>G[l][r][c])&&G[l][r][c+1]!=0&&G[l][r][c+1]!='#') { G[l][r][c+1]=G[l][r][c]+1;g[l][r][c+1]=1;dfs(l,r,c+1);}
14     if((G[l-1][r][c]=='.'||G[l-1][r][c]>G[l][r][c])&&G[l-1][r][c]!=0&&G[l-1][r][c]!='#') { G[l-1][r][c]=G[l][r][c]+1;g[l-1][r][c]=1;dfs(l-1,r,c);}
15}
16
17int main()
18{    
19     int i,j,k,l,r,c,sl,sr,sc,el,er,ec;  //起點,終點 
20     while(cin>>l>>r>>c,l||r||c)
21     {
22        memset(G,0,sizeof (G));
23        memset(g,0,sizeof (g));
24        for(i=1; i<=l ;i++)
25        for(j=1; j<=r; j++)
26        for(k=1; k<=c; k++)
27        {
28          cin>>G[i][j][k];
29          if(G[i][j][k]=='S')
30          { sl=i; sr=j; sc=j; G[i][j][k]=1; g[i][j][k]=1; }
31          else if(G[i][j][k]=='E')
32          {el=i; er=j; ec=k; G[i][j][k]=127; }
33        }           
34        
35        dfs(sl,sr,sc); 
36      /**//*  for(i=1; i<=l ; i++,cout<<endl)
37        for(j=1; j<=r; j++,cout<<endl)
38        for(k=1; k<=c; k++)
39        cout<<(int)G[i][j][k]<<" ";
40        for(i=1; i<=l ; i++,cout<<endl)
41        for(j=1; j<=r; j++,cout<<endl)
42        for(k=1; k<=c; k++)
43        cout<<(int)g[i][j][k]<<" ";
44        */if(g[el][er][ec]==0)cout<<"Trapped!"<<endl;
45        else cout<<"Escaped in "<<int(G[el][er][ec]-1)<<" minute(s)."<<endl;
46     }
47    // system("pause");
48    return 0;
49}

寫個BFS終于過了,只要在平面的迷宮基礎上在垂直方向往上,往下都搜兩次就可以了
 1 #include<iostream>
 2 #include<string.h>
 3 #include<queue>
 4 using namespace std;
 5 char G[35][35][35];
 6 int cnt[35][35][35];
 7 struct type
 8 int l,r,c; };
 9 
10 int main()
11 {
12     int l,c,r,sl,sc,sr,el,ec,er,i,j,k;
13     void bfs(int sl,int sr,int sc);
14     while(cin>>l>>r>>c,l||c||r)
15     {
16       memset(G,0,sizeof (G));
17       memset(cnt,0,sizeof (cnt));
18       for(i=1; i<=l; i++)
19       for(j=1; j<=r; j++)
20       for(k=1; k<=c; k++)
21       {
22         cin>>G[i][j][k];
23         if(G[i][j][k]=='S'){sl=i; sr=j; sc=k; }
24         else if(G[i][j][k]=='E'){el=i; er=j; ec=k; }
25       }
26     
27       bfs(sl,sr,sc);
28    //  for(i=1; i<=l; i++,cout<<endl)
29     // for(j=1; j<=r; j++,cout<<endl)
30      //for(k=1; k<=c; k++)
31      //cout<<cnt[i][j][k]<<' ';
32     
33     if(el==sl&&er==sr&&ec==sc)cout<<"Escaped in "<<0<<" minute(s). "<<endl;
34     else if(cnt[el][er][ec]>0)cout<<"Escaped in "<<cnt[el][er][ec]<<" minute(s). "<<endl;
35     else cout<<"Trapped! "<<endl;
36     }
37    // system("pause");
38     return 0;
39 }
40 
41 bool valid(int l,int r,int c)
42 {
43   return (G[l][r][c]=='.'||G[l][r][c]=='E');  
44 }
45 
46 void bfs(int sl,int sr, int sc)
47 {
48   queue<struct type> q;
49   struct type tem; tem.l=sl; tem.r=sr; tem.c=sc; 
50   q.push(tem);
51   while(q.size())
52   {
53     tem=q.front(); q.pop();
54     int l=tem.l,r=tem.r,c=tem.c;
55     if(valid(l,r+1,c)&&cnt[l][r+1][c]==0){cnt[l][r+1][c]=cnt[l][r][c]+1;tem.l=l; tem.r=r+1; tem.c=c; q.push(tem); }
56     if(valid(l,r-1,c)&&cnt[l][r-1][c]==0){cnt[l][r-1][c]=cnt[l][r][c]+1;tem.l=l; tem.r=r-1; tem.c=c; q.push(tem); }
57     if(valid(l,r,c+1)&&cnt[l][r][c+1]==0){cnt[l][r][c+1]=cnt[l][r][c]+1;tem.l=l; tem.r=r; tem.c=c+1; q.push(tem); }
58     if(valid(l,r,c-1)&&cnt[l][r][c-1]==0){cnt[l][r][c-1]=cnt[l][r][c]+1;tem.l=l; tem.r=r; tem.c=c-1; q.push(tem); }
59     if(valid(l-1,r,c)&&cnt[l-1][r][c]==0){cnt[l-1][r][c]=cnt[l][r][c]+1;tem.l=l-1; tem.r=r; tem.c=c; q.push(tem); }
60     if(valid(l+1,r,c)&&cnt[l+1][r][c]==0){cnt[l+1][r][c]=cnt[l][r][c]+1;tem.l=l+1; tem.r=r; tem.c=c; q.push(tem); }
61     
62   }
63 }

posted on 2010-05-28 21:50 田兵 閱讀(1013) 評論(0)  編輯 收藏 引用 所屬分類: 算法筆記

<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

導航

統計

常用鏈接

留言簿(2)

隨筆分類(65)

隨筆檔案(65)

文章檔案(2)

ACM

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久久国产精品厨房| 亚洲毛片一区| 亚洲在线观看| 欧美人与性动交a欧美精品| 好吊视频一区二区三区四区 | 久久精品夜夜夜夜久久| 国产精品久久999| 亚洲最新视频在线| 91久久综合| 女人天堂亚洲aⅴ在线观看| 亚洲第一黄色网| 另类尿喷潮videofree| 欧美一区二区三区四区在线观看地址| 欧美午夜宅男影院在线观看| 樱桃视频在线观看一区| av不卡在线观看| 亚洲人成毛片在线播放女女| 欧美理论在线| 日韩午夜在线观看视频| 亚洲日本在线观看| 欧美性视频网站| 午夜久久黄色| 欧美一级精品大片| 樱桃成人精品视频在线播放| 久久综合久久美利坚合众国| 久久五月天婷婷| 亚洲欧洲一区二区天堂久久 | 最近看过的日韩成人| 欧美高清日韩| 欧美日本一区| 欧美一级日韩一级| 久久人91精品久久久久久不卡| 在线观看日韩av| 久久午夜国产精品| 免费不卡亚洲欧美| 亚洲视频在线一区| 香蕉精品999视频一区二区 | 蜜桃久久av一区| 牛牛影视久久网| 在线播放不卡| 亚洲国产成人午夜在线一区| 免费在线欧美黄色| 亚洲欧美日韩直播| 久久一区二区三区av| 一本久道久久综合中文字幕| 亚洲欧美www| 亚洲人成人77777线观看| 99视频精品全国免费| 韩国欧美一区| 日韩午夜激情| 亚洲成人在线网| 亚洲视频一区二区| 亚洲国产岛国毛片在线| 亚洲视频在线视频| 亚洲高清视频一区| 亚洲免费视频一区二区| 99re成人精品视频| 午夜精品偷拍| 99伊人成综合| 久久久噜噜噜久噜久久| 亚洲男女自偷自拍| 久久男人av资源网站| 亚洲欧美一区二区原创| 欧美成人亚洲| 免费成人av在线| 国产日韩三区| 在线午夜精品自拍| 日韩视频专区| 欧美a级片网| 美女成人午夜| 国内自拍视频一区二区三区| 亚洲视频中文字幕| 在线一区二区三区四区五区| 免费亚洲电影在线| 久久人人97超碰精品888| 国产精品女人毛片| 亚洲丝袜av一区| 一区二区日韩免费看| 欧美成人伊人久久综合网| 久久久亚洲午夜电影| 国产精品成人在线| 日韩亚洲欧美一区二区三区| 日韩网站免费观看| 欧美大片免费看| 亚洲国产精品电影| 亚洲人成精品久久久久| 免费在线观看一区二区| 欧美激情第8页| 亚洲国产精品久久精品怡红院| 久久久亚洲高清| 蜜桃视频一区| 91久久久久久久久久久久久| 久久精品72免费观看| 亚洲欧美久久久| 国产精品一香蕉国产线看观看| 亚洲视频一区二区在线观看 | 国产精品国产三级国产aⅴ浪潮| 亚洲美女区一区| 正在播放亚洲一区| 欧美精品亚洲二区| 99精品欧美一区二区蜜桃免费| 亚洲影音一区| 国产欧美69| 久久久久国产精品人| 亚洲国产日韩欧美综合久久| 日韩视频一区二区三区| 欧美三区美女| 亚洲欧美成人一区二区在线电影| 久久精品国产综合| 亚洲国产欧美日韩另类综合| 欧美激情一区二区久久久| 日韩视频久久| 99人久久精品视频最新地址| 欧美国产视频一区二区| 国产精品99久久久久久www| 久久av一区二区三区漫画| 好看的av在线不卡观看| 欧美国产日韩一区二区三区| 夜夜爽av福利精品导航| 久久久久久一区| 91久久精品国产91久久性色| 欧美无乱码久久久免费午夜一区 | 欧美日韩中文另类| 欧美在线免费观看视频| 亚洲电影在线免费观看| 午夜精品久久久久久久男人的天堂| 国产一区二区中文字幕免费看| 欧美高清视频一区二区| 午夜精品福利在线| 亚洲国产一区二区在线| 午夜国产欧美理论在线播放| 欧美性色综合| 欧美xx视频| 久久er精品视频| 一区二区欧美亚洲| 免费高清在线视频一区·| 亚洲欧美日韩电影| 91久久中文| 狠狠色丁香婷综合久久| 国产精品久久久久一区二区三区共| 久久免费视频网| 亚洲欧美日韩中文在线制服| 亚洲国产精品123| 亚洲综合激情| 一本久道久久综合婷婷鲸鱼| 加勒比av一区二区| 国产日韩欧美在线看| 欧美色中文字幕| 欧美成人免费视频| 久久精品久久99精品久久| 亚洲制服欧美中文字幕中文字幕| 久久久久在线| 在线亚洲成人| 99成人免费视频| 亚洲黄一区二区三区| 黄色成人精品网站| 国产精品久久久久久超碰| 欧美性理论片在线观看片免费| 国产精品毛片一区二区三区| 国产精品视频一区二区高潮| 国产欧美欧美| 亚洲大黄网站| 99在线观看免费视频精品观看| 亚洲一区二区三区国产| 久久成人精品视频| 免费视频亚洲| 日韩一区二区福利| 亚洲欧美日韩国产综合| 久久久久.com| 欧美日本亚洲视频| 国产精品午夜视频| 伊人久久综合| 亚洲午夜视频| 免费成人黄色av| 99热免费精品在线观看| 欧美在线视频a| 欧美精品一区在线| 国产日本欧美视频| 亚洲精品美女在线观看| 欧美一区在线看| 亚洲国产一二三| 亚洲欧美视频在线观看| 欧美高清一区| 国产日韩精品视频一区二区三区| 亚洲高清在线播放| 亚洲欧美视频在线观看视频| 欧美成人蜜桃| 香蕉尹人综合在线观看| 欧美精品一区二区高清在线观看| 国产精品亚发布| 亚洲美女精品成人在线视频| 久久久久久久综合狠狠综合| 亚洲欧洲久久| 久久久久一区| 国产日韩欧美一区二区三区四区 | 欧美大片免费看| 国产日韩一级二级三级| 中文国产成人精品久久一| 免费亚洲婷婷| 欧美在线观看一区二区|