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

pku Left labyrinths DFS網格圖搜索-注意這種非優先路搜索判重一定要帶方向向量

題目意思很簡單,一個迷宮,問是否能夠從入口處進入,在岔道口處向左拐,問采取這種策略能夠走到中心。
由于這里不是全DFS,而是具有某種優先級順序,在這里,優先級是指一直向左拐。判重的時候不能僅僅判斷這個格子是否走過,還要加上方向向量,即從什么方向走入這個格子的。
  1 # include <iostream>
  2 # include <cstring>
  3 # include <cstdio>
  4 using namespace std;
  5 char map[105][105];
  6 bool used[105][105][4];//方向:0-向上 1-向右 2-向下 3-向左
  7 int n,m;
  8 int sr=-1,sc=-1;
  9 inline bool chk(int r,int c)
 10 {
 11    if(r+1<n&&r-1>=0&&map[r+1][c]=='#'&&map[r-1][c]=='#'return true;
 12    else if(c+1<m&&c-1>=0&&map[r][c-1]=='#'&&map[r][c+1]=='#'return true;
 13    else return false;
 14 }
 15 inline int encode(int r,int c,int dir)
 16 {  
 17      return (((r<<7)|c)<<2)|dir;
 18 }
 19 inline bool legal(int r,int c)
 20 {
 21    if(r>=0&&r<n&&c>=0&&c<m&&map[r][c]=='.'return true;
 22    else return false;
 23 }
 24 void findstart(int r,int c)
 25 {
 26    if(r>=n||r<0||c>=m||c<0||map[r][c]!='.'return;
 27    if(chk(r,c))
 28    {
 29       sr=r;
 30       sc=c;
 31       return;
 32    }
 33    map[r][c]=' ';
 34    findstart(r+1,c);
 35    findstart(r-1,c);
 36    findstart(r,c+1);
 37    findstart(r,c-1);
 38 }
 39 bool dfs(int r,int c,int dir)
 40 {
 41   // printf("%d %d %d\n",r,c,dir);
 42   // system("pause");
 43    if(used[r][c][dir]) return false;
 44    else
 45    {
 46        if(legal(r,c)&&legal(r+1,c)&&legal(r,c+1)&&legal(r+1,c+1)||
 47           legal(r,c-1)&&legal(r,c)&&legal(r+1,c-1)&&legal(r+1,c)||
 48           legal(r-1,c)&&legal(r,c)&&legal(r-1,c+1)&&legal(r,c+1)||
 49           legal(r-1,c-1)&&legal(r-1,c)&&legal(r,c-1)&&legal(r,c)) 
 50           return true;
 51        used[r][c][dir]=true;
 52        switch(dir)
 53        {
 54          case 0:
 55               if(legal(r,c-1)) return dfs(r,c-1,3);
 56               else if(legal(r-1,c)) return dfs(r-1,c,0);
 57               else if(legal(r,c+1)) return dfs(r,c+1,1);
 58               break;
 59          case 1:
 60               if(legal(r-1,c)) return dfs(r-1,c,0);
 61               else if(legal(r,c+1)) return dfs(r,c+1,1);
 62               else if(legal(r+1,c)) return dfs(r+1,c,2);
 63               break;
 64          case 2:
 65               if(legal(r,c+1)) return dfs(r,c+1,1);
 66               else if(legal(r+1,c)) return dfs(r+1,c,2);
 67               else if(legal(r,c-1)) return dfs(r,c-1,3);
 68               break;
 69          case 3:
 70               if(legal(r+1,c)) return dfs(r+1,c,2);
 71               else if(legal(r,c-1)) return dfs(r,c-1,3);
 72               else if(legal(r-1,c)) return dfs(r-1,c,0);
 73               break;
 74        } ;
 75        return false;
 76    }
 77    
 78 }
 79 int main()
 80 {
 81     //int n,m;
 82     scanf("%d%d",&n,&m);
 83     for(int i=0;i<n;i++)
 84        scanf("%s",map[i]);
 85     for(int i=0;i<n;i++)
 86     {
 87         if(map[i][0]=='.')
 88            findstart(i,0);
 89         if(map[i][m-1]=='.')
 90            findstart(i,m-1);
 91     }
 92     for(int i=0;i<m;i++)
 93     {
 94         if(map[0][i]=='.')
 95            findstart(0,i);
 96         if(map[n-1][i]=='.')
 97            findstart(n-1,i);
 98     }
 99   //  for(int i=0;i<n;i++)
100     //  printf("%s\n",map[i]);
101   //  system("pause");
102     memset(used,false,sizeof(used));
103     if(sr+1<n&&sr-1>=0&&map[sr+1][sc]=='#'&&map[sr-1][sc]=='#')
104        if(sc+1>=m||map[sr][sc+1]==' ')
105           printf("%s\n",dfs(sr,sc,3)?"YES":"NO");
106        else
107           printf("%s\n",dfs(sr,sc,1)?"YES":"NO");
108     else
109        if(sr+1>=n||map[sr+1][sc]==' ')
110           printf("%s\n",dfs(sr,sc,0)?"YES":"NO");
111        else
112           printf("%s\n",dfs(sr,sc,2)?"YES":"NO");
113     //system("pause");
114     return 0;
115            
116 }
117 

posted on 2010-10-15 16:09 yzhw 閱讀(212) 評論(0)  編輯 收藏 引用 所屬分類: search

<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導航

統計

公告

統計系統

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲人体大胆视频| 国产精品久久久久久久久借妻| 欧美电影免费观看网站| 老司机一区二区| 亚洲免费观看视频| 国产精品区一区二区三区| 在线亚洲自拍| 欧美14一18处毛片| 欧美在线免费视屏| 亚洲一区二区三区免费在线观看| 国产日韩欧美在线播放| 欧美啪啪成人vr| 免费高清在线一区| 欧美在线日韩在线| 亚洲天堂成人在线观看| 99亚洲一区二区| 亚洲精品偷拍| 亚洲欧洲一二三| 久久人人97超碰国产公开结果| 国产精品一区二区久久久久| 欧美激情偷拍| 欧美激情精品久久久久久久变态| 欧美在线观看视频| 久久精品视频免费观看| 久久久久国产一区二区| 久久精品成人一区二区三区 | 欧美在线播放视频| 这里只有精品电影| 一区二区三区回区在观看免费视频| 亚洲国产日韩欧美| 午夜精品999| 久久国内精品视频| 欧美日韩你懂的| 国产精品蜜臀在线观看| 国产精品久久久久一区| 黄网站免费久久| 一区二区三区欧美在线| 欧美在线3区| 亚洲国产日韩欧美在线99 | 午夜精彩视频在线观看不卡| 久久久www成人免费精品| 欧美成人蜜桃| 亚洲二区视频| 亚洲女女做受ⅹxx高潮| 午夜视频在线观看一区| 欧美大色视频| 中文国产成人精品| 亚洲免费小视频| 欧美日韩亚洲成人| 最新中文字幕一区二区三区| 久久精品在这里| 亚洲一区二区三区中文字幕| 久久久久久久久久看片| 欧美亚一区二区| 亚洲一区免费在线观看| 久久在线免费观看| 久久精品欧美| 一区二区福利| 久久aⅴ乱码一区二区三区| 国内外成人免费激情在线视频网站| 久久午夜影视| 欧美国产日韩一区二区在线观看| 久久爱www久久做| 亚洲社区在线观看| 老**午夜毛片一区二区三区| 亚洲欧美激情在线视频| 欧美伊人久久久久久午夜久久久久| 一区二区三区自拍| 在线视频欧美日韩| 亚洲美女在线观看| 麻豆免费精品视频| 久久精品人人| 国产美女精品视频| 亚洲人成绝费网站色www| 国产一区高清视频| 亚洲女同在线| 欧美一区亚洲二区| 国产精自产拍久久久久久蜜 | 国产亚洲美州欧州综合国| 亚洲理伦电影| 亚洲素人在线| 国产精品久久久久久五月尺| 亚洲美女中出| 亚洲综合精品| 国产一区二区三区奇米久涩| 午夜一区二区三区不卡视频| 亚洲欧美视频一区| 国产日韩专区| 欧美福利专区| 一本色道久久综合精品竹菊| 亚洲夜晚福利在线观看| 国产精品毛片va一区二区三区| 亚洲视频在线一区| 久久久久国产精品厨房| 亚洲黄色在线| 国产精品久久久久久亚洲调教 | 日韩视频三区| 久久福利影视| 亚洲视频观看| 国内外成人免费激情在线视频| 蜜桃av久久久亚洲精品| 一区二区三区免费在线观看| 欧美一级视频免费在线观看| 国产私拍一区| 欧美日韩在线高清| 久久久午夜电影| 亚洲性视频h| 亚洲区在线播放| 久久色在线观看| 亚洲欧美日韩国产中文在线| 亚洲成人在线视频网站| 国产亚洲欧美aaaa| 国产色综合久久| 国产欧美一区二区三区沐欲| 欧美日韩精品在线观看| 男女精品网站| 欧美国产精品劲爆| 欧美成人精品激情在线观看| 久久av最新网址| 欧美精品一区在线播放| 亚洲精品123区| 黄色成人在线网站| 亚洲盗摄视频| 伊人伊人伊人久久| 欧美一区二区三区婷婷月色 | 韩曰欧美视频免费观看| 欧美www视频| 国产日韩综合| 免费看成人av| 久久精品一区二区三区不卡| 99riav国产精品| 亚洲黄网站在线观看| 久久精品国产第一区二区三区最新章节| 99这里有精品| 亚洲一区二区三区在线观看视频| 亚洲免费久久| 亚洲少妇自拍| 欧美国产精品v| 99国产精品久久久久久久| 日韩午夜高潮| 91久久中文| 亚洲欧美日韩成人| 久久精品夜色噜噜亚洲aⅴ| 欧美岛国激情| 亚洲——在线| 牛牛影视久久网| 国产精品日本一区二区| 91久久午夜| 裸体女人亚洲精品一区| 日韩视频免费看| 你懂的亚洲视频| 亚洲激情视频网站| 久久久久久亚洲精品不卡4k岛国| 欧美国产三区| 欧美影视一区| 国产欧美日韩另类一区| 在线综合视频| 99热免费精品| 国产精品久久久久久久午夜片 | 国产区精品视频| 亚洲欧美日韩国产综合精品二区| 美女露胸一区二区三区| 久久精品欧美日韩精品| 国产亚洲精品成人av久久ww| 亚洲一区二区三区激情| 亚洲自拍偷拍视频| 国产酒店精品激情| 欧美一区二区视频免费观看| 亚洲无线观看| 国产欧美成人| 欧美sm极限捆绑bd| 欧美日韩大片一区二区三区| 老司机精品福利视频| 在线观看亚洲一区| 亚洲国产精品va在线观看黑人| 久久一日本道色综合久久| 亚洲日本中文| 亚洲午夜视频| 一区二区在线不卡| 亚洲精品欧美激情| 国产一区二区三区黄视频| 久久久久青草大香线综合精品| 久久亚洲欧洲| 久久久99久久精品女同性| 久久婷婷色综合| 亚洲欧美一级二级三级| 美腿丝袜亚洲色图| 久久免费高清视频| 国产伦精品一区二区三| 亚洲激情影院| 亚洲精选久久| 久久这里有精品15一区二区三区| 亚洲一区三区视频在线观看| 另类亚洲自拍| 欧美成人精品激情在线观看| 国产精品久久国产愉拍 | 亚洲视频一区二区| 一区二区三区高清| 国产精品你懂的| 亚洲私人黄色宅男|