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

A Za, A Za, Fighting...

堅(jiān)信:勤能補(bǔ)拙

PKU 1475 Pushing Boxes

問題:
http://acm.pku.edu.cn/JudgeOnline/problem?id=1475

思路:
很復(fù)雜的一題,從discuss知道可以采用嵌套的BFS來做,不過始終不知道如何下手
通過這題,發(fā)現(xiàn)自己對(duì)于復(fù)雜問題的coding能力比較弱,不能很好的理清其中的邏輯關(guān)系,需要多多鍛煉

這題的關(guān)鍵是抓住box的每一次擴(kuò)展,都對(duì)應(yīng)地存在一個(gè)person的起始位置,兩者需要同時(shí)記錄

參考:
http://www.chhaya.me/?p=147

代碼:
  1 #include<stdio.h>
  2 #include<stdlib.h>
  3 #include<string.h>
  4 #define MAX_LEN 21
  5 /* north, south, east, west */
  6 const int dx[] = {-1100};
  7 const int dy[] = {001-1};
  8 const char dir_box[] = "NSEW";
  9 const char dir_psn[] = "nsew";
 10 int r, c;
 11 int px, py, bx, by, btx, bty;
 12 char map[MAX_LEN][MAX_LEN];
 13 struct EACH {
 14     int x, y;
 15     int id;
 16     int pre;
 17     int dir;
 18 };
 19 struct EACH cur_each, tmp_each, cur_psn, tmp_psn, box_queue[MAX_LEN*MAX_LEN], psn_queue[MAX_LEN*MAX_LEN];
 20 struct {
 21     int x, y;
 22 }persons[MAX_LEN*MAX_LEN];
 23 int visited_box[MAX_LEN][MAX_LEN];
 24 int visited_psn[MAX_LEN][MAX_LEN];
 25 int cnt[MAX_LEN*MAX_LEN];
 26 char seq[MAX_LEN*MAX_LEN][MAX_LEN*MAX_LEN];
 27 
 28 int
 29 is_valid_box(struct EACH item, int dir)
 30 {
 31     int tmpx, tmpy;
 32     if(item.x<0 || item.x>=|| item.y<0 || item.y>=|| map[item.x][item.y]=='#')
 33         return 0;
 34     /* see if there exists a position for person to push */
 35     tmpx = item.x-2*dx[dir];
 36     tmpy = item.y-2*dy[dir];
 37     if(tmpx<0 || tmpx>=|| tmpy<0 || tmpy>=|| map[tmpx][tmpy]=='#')
 38         return 0;
 39     return 1;
 40 }
 41 
 42 int
 43 is_valid_psn(int psnx, int psny, int boxx, int boxy)
 44 {
 45     if(psnx<0 || psnx>=|| psny<0 || psny>=|| map[psnx][psny]=='#')
 46         return 0;
 47     /* path of person can't cover the box */
 48     if(psnx==boxx && psny==boxy)
 49         return 0;
 50     return 1;
 51 }
 52 
 53 int
 54 psn_bfs(int startx, int starty, int endx, int endy, int dir, int index)
 55 {
 56     int i, head, tail;
 57     struct EACH tmp;
 58     memset(visited_psn, 0sizeof(visited_psn));
 59     head = -1;
 60     tail = 0;
 61     psn_queue[tail].x = startx;
 62     psn_queue[tail].y = starty;
 63     psn_queue[tail].pre = -1;
 64     visited_psn[startx][starty] = 1;
 65     while(head < tail) {
 66         ++head;
 67         cur_psn = psn_queue[head];
 68         if(cur_psn.x==endx && cur_psn.y==endy) {
 69             /* record */
 70             /* here 'index' should plus 1, according to box_bfs */
 71             persons[index+1].x = cur_psn.x + dx[dir];
 72             persons[index+1].y = cur_psn.y + dy[dir];
 73             cnt[index+1= 0;
 74             tmp = cur_psn;
 75             while(tmp.pre != -1) {
 76                 seq[index+1][cnt[index+1]++= dir_psn[tmp.dir];
 77                 tmp = psn_queue[tmp.pre];
 78             }
 79             return 1;
 80         }
 81         for(i=0; i<4; i++) {
 82             tmp_psn.x = cur_psn.x + dx[i];
 83             tmp_psn.y = cur_psn.y + dy[i];
 84             if(is_valid_psn(tmp_psn.x, tmp_psn.y, endx+dx[dir], endy+dy[dir]) && !visited_psn[tmp_psn.x][tmp_psn.y]) {
 85                 ++tail;
 86                 tmp_psn.pre = head;
 87                 tmp_psn.dir = i;
 88                 psn_queue[tail] = tmp_psn;
 89                 visited_psn[tmp_psn.x][tmp_psn.y] = 1;
 90             }
 91         }
 92     }
 93     return 0;
 94 }
 95 
 96 void
 97 output(struct EACH *end)
 98 {
 99     int i, index;
100     if(end->pre == -1)
101         return;
102     output(box_queue+(end->pre));
103     index = end->id;
104     for(i=cnt[index]-1; i>=0; i--)
105         printf("%c", seq[index][i]);
106     printf("%c", dir_box[end->dir]);
107 }
108 
109 void
110 box_bfs()
111 {
112     int i, psn_rt, head, tail;
113     head = -1;
114     tail = 0;
115     memset(visited_box, 0sizeof(visited_box));
116     box_queue[tail].x = bx;
117     box_queue[tail].y = by;
118     box_queue[tail].pre = -1;
119     box_queue[tail].id = tail;
120     visited_box[bx][by] = 1;
121     persons[tail].x = px;
122     persons[tail].y = py;
123     while(head < tail) {
124         ++head;
125         cur_each = box_queue[head];
126         if(cur_each.x==btx && cur_each.y==bty) {
127             /* output */
128             output(box_queue+head);
129             return;
130         }
131         for(i=0; i<4; i++) {
132             tmp_each.x = cur_each.x + dx[i];
133             tmp_each.y = cur_each.y + dy[i];
134             if(is_valid_box(tmp_each, i) && !visited_box[tmp_each.x][tmp_each.y]) {
135                 /* bfs for person */
136                 psn_rt = psn_bfs(persons[head].x, persons[head].y, tmp_each.x-2*dx[i], tmp_each.y-2*dy[i], i, tail);
137                 if(psn_rt) {
138                     ++tail;
139                     tmp_each.dir = i;
140                     tmp_each.pre = head;
141                     tmp_each.id = tail;
142                     box_queue[tail] = tmp_each;
143                     visited_box[tmp_each.x][tmp_each.y] = 1;
144                 }
145             }
146         }
147     }
148     printf("Impossible.");
149 }
150 
151 int
152 main(int argc, char **argv)
153 {
154     int i, j, tests = 0;
155     while(scanf("%d %d"&r, &c) != EOF) {
156         if(r==0 && c==0)
157             break;
158         for(i=0; i<r; i++) {
159             scanf("%s", map[i]);
160             for(j=0; j<c; j++) {
161                 if(map[i][j] == 'S') {
162                     px = i;
163                     py = j;
164                 } else if(map[i][j] == 'B') {
165                     bx = i;
166                     by = j;
167                 } else if(map[i][j] == 'T') {
168                     btx = i;
169                     bty = j;
170                 }
171             }
172         }
173         printf("Maze #%d\n"++tests);
174         /* bfs */
175         box_bfs();
176         printf("\n\n");
177     }
178 }

posted on 2010-08-05 12:14 simplyzhao 閱讀(283) 評(píng)論(0)  編輯 收藏 引用 所屬分類: B_搜索

導(dǎo)航

<2011年8月>
31123456
78910111213
14151617181920
21222324252627
28293031123
45678910

統(tǒng)計(jì)

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久亚洲影音av资源网| 欧美日韩精品免费观看| 欧美成人dvd在线视频| 亚洲自拍三区| 亚洲欧美成人一区二区三区| 一区二区三区国产精华| 99成人在线| 亚洲欧美国产精品va在线观看| 一区二区三区四区蜜桃| 亚洲综合日韩在线| 久久精品免视看| 亚洲一区二区久久| 一本在线高清不卡dvd | 国产精品三级久久久久久电影| 欧美日韩黄色一区二区| 国产精品综合久久久| 国产亚洲精品美女| 亚洲区欧美区| 先锋影音国产一区| 欧美电影在线免费观看网站| 日韩视频在线你懂得| 亚洲一区二区三区高清不卡| 久久精品国产2020观看福利| 欧美顶级少妇做爰| 国产一区二区三区精品欧美日韩一区二区三区 | 国产视频欧美视频| 亚洲激情欧美激情| 性亚洲最疯狂xxxx高清| 欧美成人午夜视频| 亚洲一区精彩视频| 欧美va天堂| 国产欧美日韩视频一区二区三区| 亚洲国产高清一区| 久久精品国产99国产精品| 亚洲人成啪啪网站| 性xx色xx综合久久久xx| 欧美日韩国产在线| 亚洲国产视频一区二区| 久久国产精彩视频| 一区二区三区精品在线 | 日韩视频精品| 免费观看成人www动漫视频| 国产视频观看一区| 亚洲综合首页| 99精品久久久| 欧美区在线播放| 曰韩精品一区二区| 久久久久久欧美| 亚洲欧美久久久| 欧美午夜精品理论片a级大开眼界| 1024亚洲| 免费亚洲电影在线| 久久精品国产99精品国产亚洲性色| 国产精品第13页| 亚洲一区国产| 日韩一级在线观看| 欧美精品免费播放| 亚洲欧美成人一区二区在线电影| 国产日韩视频| 亚洲伊人伊色伊影伊综合网| 欧美电影在线观看完整版| 久久精品色图| 国产一区二区久久精品| 久久精品国产亚洲aⅴ| 亚洲一级黄色| 国产精品亚洲不卡a| 亚洲欧美精品一区| 亚洲视频在线观看| 国产精品日本一区二区| 久久精品国产成人| 久久精品女人| 亚洲二区三区四区| 最近中文字幕mv在线一区二区三区四区| 久久野战av| 亚洲人久久久| 一区二区三区国产在线| 国产欧美精品一区二区色综合 | 久久天堂国产精品| 亚洲人成7777| 99亚洲视频| 国产三级精品三级| 久久在线播放| 欧美国产精品久久| 亚洲欧美国产毛片在线| 久久久999国产| 夜夜嗨av一区二区三区网页| 亚洲午夜国产成人av电影男同| 国产伦精品一区二区三区高清版 | 一个人看的www久久| 国产精品影片在线观看| 欧美a级理论片| 欧美日韩无遮挡| 久久米奇亚洲| 欧美日本亚洲| 久久精品夜色噜噜亚洲a∨ | 亚洲电影天堂av| 国产精品免费福利| 亚洲国产精品www| 国产精品亚洲欧美| 亚洲成色777777在线观看影院| 欧美日韩美女一区二区| 久久全球大尺度高清视频| 欧美日本不卡视频| 蜜桃av噜噜一区| 国产精品色午夜在线观看| 亚洲第一黄色网| 国产综合在线看| 亚洲小说欧美另类社区| 最新国产の精品合集bt伙计| 亚洲欧美日韩在线一区| 夜夜嗨av一区二区三区| 久久久不卡网国产精品一区| 欧美精品免费在线| 欧美一区二区免费观在线| 亚洲小视频在线观看| 又紧又大又爽精品一区二区| 亚洲手机在线| 亚洲欧美三级伦理| 欧美在线视频全部完| 亚洲一区欧美激情| 最新中文字幕一区二区三区| 亚洲欧美日韩国产中文| 妖精视频成人观看www| 久久亚洲高清| 久久国产精品一区二区| 欧美视频中文一区二区三区在线观看 | 久久精品免费电影| 亚欧美中日韩视频| 欧美日韩一区二区国产| 亚洲国产精品女人久久久| 国产在线不卡精品| 午夜精品在线| 性做久久久久久久免费看| 欧美视频在线视频| 99视频超级精品| 亚洲色图自拍| 欧美日韩一区二区三区在线看 | 亚洲午夜在线观看| 欧美久久一级| 亚洲日韩成人| 在线视频日本亚洲性| 欧美日韩激情小视频| 亚洲精品少妇网址| 亚洲深夜福利视频| 国产精品高清在线| 亚洲男人的天堂在线aⅴ视频| 午夜在线视频一区二区区别| 国产精品女同互慰在线看| 亚洲网站在线观看| 欧美专区亚洲专区| ●精品国产综合乱码久久久久| 久久三级福利| 亚洲区一区二| 亚洲欧美日韩在线不卡| 国产日韩专区| 蜜臀va亚洲va欧美va天堂| 最新亚洲激情| 亚洲欧美日韩精品久久亚洲区 | 国产精品乱人伦一区二区| 亚洲一区二区影院| 久久精品视频播放| 久久大逼视频| 国内外成人免费激情在线视频网站| 欧美一区二区三区四区在线观看| 久久精品电影| 亚洲精品乱码| 国产精品乱码人人做人人爱| 久久成人综合网| 亚洲人成人一区二区在线观看| 亚洲一区二区三区激情| 国产一区二区三区的电影 | 欧美精品一区二区三区蜜桃| 日韩视频一区二区在线观看 | 国产精品一区二区三区四区 | 国产欧美大片| 麻豆成人综合网| 亚洲一二三区在线| 欧美大学生性色视频| 亚洲专区欧美专区| 在线日韩电影| 国产精品网站在线播放| 毛片基地黄久久久久久天堂| 一区二区三区精品视频在线观看| 久久一区中文字幕| 亚洲一区免费网站| 亚洲国产精品久久| 国产欧美日韩专区发布| 欧美精品手机在线| 久久精品最新地址| 亚洲午夜久久久久久久久电影网| 欧美大色视频| 久久综合九九| 欧美在线观看一区| 亚洲婷婷综合色高清在线| ●精品国产综合乱码久久久久| 国产精品影音先锋| 欧美性猛交xxxx乱大交退制版| 老鸭窝91久久精品色噜噜导演| 亚洲综合二区| 亚洲性人人天天夜夜摸|