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

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 閱讀(215) 評論(0)  編輯 收藏 引用 所屬分類: search

<2011年9月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

導航

統計

公告

統計系統

留言簿(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>
            久久久久国产精品午夜一区| 午夜视频久久久久久| 亚洲午夜电影| 亚洲国产高清在线观看视频| 久久久综合网站| 国产精品另类一区| 日韩视频中文| 亚洲婷婷综合久久一本伊一区| 嫩模写真一区二区三区三州| 影音先锋国产精品| 久久精品一区中文字幕| 91久久夜色精品国产九色| 国产精品久久久久久五月尺| 久久精品系列| 久久亚洲高清| 欧美va天堂| 国产视频一区在线| 亚洲国产精品一区制服丝袜 | 亚洲电影第1页| 国精品一区二区三区| 亚洲黄色大片| 亚洲一区二区成人| 久久av二区| 在线视频欧美一区| 亚洲久久一区| 欧美国产亚洲精品久久久8v| 国产精品高潮呻吟久久av无限| 久久久久久免费| 欧美国产日韩精品免费观看| 欧美黄色aa电影| 在线欧美小视频| 欧美伊人久久大香线蕉综合69| 欧美激情精品久久久久久黑人 | 免费h精品视频在线播放| 欧美视频精品一区| 欧美成人小视频| 国产欧美日韩亚洲| 久久综合久久综合这里只有精品| 久久久久久久久久久一区| 国产伦精品一区二区| 亚洲精品偷拍| 亚洲美女av网站| 亚洲精品人人| 国产精品久久二区二区| 亚洲风情在线资源站| 一本色道88久久加勒比精品| 亚洲中字在线| 国产在线欧美日韩| 久久一综合视频| 欧美体内she精视频在线观看| 亚洲一区国产视频| 在线成人小视频| 欧美在线999| 久久午夜激情| 一区二区三区四区五区精品视频 | 欧美日韩国产精品自在自线| 日韩亚洲不卡在线| 新67194成人永久网站| 精品99一区二区| 欧美刺激性大交免费视频| 亚洲国产精品999| 久久久久88色偷偷免费| 亚洲人成网站在线播| 国产精品久久国产愉拍 | 亚洲第一精品电影| 国产在线观看91精品一区| 国产精品亚洲综合一区在线观看| 欧美wwwwww| 久久夜色精品国产欧美乱极品| 91久久精品国产91性色| 久久久久久久久久码影片| 亚洲免费av网站| 一区二区三区.www| 亚洲女同性videos| 欧美区视频在线观看| 欧美成人免费在线观看| 欧美黄色网络| 国产精品v欧美精品v日韩| 国产人久久人人人人爽| 国内一区二区在线视频观看| 国内精品模特av私拍在线观看| 欧美日韩第一页| 国产免费成人在线视频| 国产在线精品二区| 有坂深雪在线一区| 亚洲美女福利视频网站| 久久精品国产2020观看福利| 久久欧美中文字幕| 久久久人成影片一区二区三区观看| 在线观看日韩av先锋影音电影院| 欧美精品日韩三级| 欧美国产精品| 国产亚洲精品aa| 一区视频在线播放| 欧美成人黄色小视频| 一区二区三区欧美在线| 久久精品国产77777蜜臀| 欧美激情一级片一区二区| 国产目拍亚洲精品99久久精品| 国产酒店精品激情| 99热这里只有精品8| 久久久噜噜噜| 中文亚洲视频在线| 亚洲欧美久久久久一区二区三区| 久久久久久夜精品精品免费| 亚洲午夜在线| 国产精品久久久久久久免费软件 | 亚洲大胆在线| 亚洲国产一区二区在线| 欧美激情在线观看| 亚洲一卡久久| 亚洲一级黄色| 国内一区二区在线视频观看| 欧美激情一区| 国产私拍一区| 亚洲精品自在久久| 在线不卡中文字幕| 亚洲无限乱码一二三四麻| 狠狠久久亚洲欧美专区| 欧美高清视频在线| 国产综合18久久久久久| 一区二区三区四区五区在线| 国产综合精品| 亚洲一区二区三区在线看| 最新国产精品拍自在线播放| 久久gogo国模啪啪人体图| 9l国产精品久久久久麻豆| 国产一区二区三区在线免费观看| 夜夜嗨网站十八久久| 99www免费人成精品| 欧美aa国产视频| 久久亚洲私人国产精品va| 欧美视频官网| 亚洲午夜精品久久| 亚洲美女一区| 狠狠入ady亚洲精品| 欧美视频在线看| 美女免费视频一区| 亚洲国产欧美在线| 欧美亚洲网站| 亚洲欧美成人一区二区三区| 亚洲高清资源综合久久精品| 一本色道久久综合亚洲精品婷婷| 免费视频一区| 亚洲美女av黄| 欧美一区午夜精品| 亚洲丁香婷深爱综合| 欧美一区二区三区喷汁尤物| 欧美成年视频| 午夜久久资源| 在线观看欧美成人| 国产精品二区二区三区| 久久av老司机精品网站导航| 久久不见久久见免费视频1| 亚洲国产欧美在线人成| 欧美色精品天天在线观看视频| 欧美一区二区三区视频免费播放| 欧美v国产在线一区二区三区| 亚洲精品日韩在线| 亚洲欧美国产高清| 日韩视频二区| 欧美中文字幕在线| 激情文学综合丁香| 欧美成人免费全部观看天天性色| 久久精品亚洲精品| 久久国产主播精品| 久久天堂av综合合色| 亚洲人成高清| 欧美一区二区三区播放老司机| 在线免费观看欧美| 麻豆精品在线视频| 亚洲一区二区三区777| 国产主播在线一区| 亚洲嫩草精品久久| 欧美国产日韩视频| 久久久久久久久久久一区| 亚洲主播在线播放| 在线亚洲美日韩| 亚洲无线一线二线三线区别av| 亚洲大片在线| 久久久www免费人成黑人精品| 一区二区三区鲁丝不卡| 亚洲精品国产精品乱码不99 | 欧美日韩高清一区| 欧美日韩国产色综合一二三四| 欧美成人a∨高清免费观看| 另类图片综合电影| 欧美日韩国产综合新一区| 国产精品国产三级国产普通话三级| 欧美日韩一区二| 国产精品久久久久久久久久尿| 欧美日韩性生活视频| 韩国三级电影久久久久久| 一区一区视频| 欧美一区二区三区精品| 久热re这里精品视频在线6| 亚洲高清一二三区| 亚洲网址在线| 欧美日韩国产美| 亚洲第一精品夜夜躁人人爽|